一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

php natsort內核函數淺析第1/2頁

官方手冊(http://us.php.NET/manual/en/function.natsort.php
復制代碼 代碼如下:
bool natsort ( array &$array )
This function implements a sort algorithm that orders alphanumeric strings in the way a human being would while maintaining key/value associations. This is described as a "natural ordering". An example of the difference between this algorithm and the regular computer string sorting algorithms (used in sort()) can be seen in the example below.

據官方手冊還可以得到這樣的結果:

img1.png img2.png img10.png img12.png

顯然這很適合對類似文件名的排序。從結果看這種自然算法應該是去掉頭和尾的非數字部分,然后對留下來的數字部分進行排序,究竟是不是,還是看一下php源碼吧。
復制代碼 代碼如下:
//從ext/standard/array.c抽取的相關代碼如下
static int php_array_natural_general_compare(const void *a, const void *b, int fold_case) /* {{{ */
{
    Bucket *f, *s;
    zval *fval, *sval;
    zval first, second;
    int result;
    f = *((Bucket **) a);
    s = *((Bucket **) b);
    fval = *((zval **) f->pData);
    sval = *((zval **) s->pData);
    first = *fval;
    second = *sval;
    if (Z_TYPE_P(fval) != IS_STRING) {
        zval_copy_ctor(&first);
        convert_to_string(&first);
    }
    if (Z_TYPE_P(sval) != IS_STRING) {
        zval_copy_ctor(&second);
        convert_to_string(&second);
    }
    result = strnatcmp_ex(Z_STRVAL(first), Z_STRLEN(first), Z_STRVAL(second), Z_STRLEN(second), fold_case);
    if (Z_TYPE_P(fval) != IS_STRING) {
        zval_dtor(&first);
    }
    if (Z_TYPE_P(sval) != IS_STRING) {
        zval_dtor(&second);
    }
    return result;
}
/* }}} */
static int php_array_natural_compare(const void *a, const void *b TSRMLS_DC) /* {{{ */
{
    return php_array_natural_general_compare(a, b, 0);
}
/* }}} */
static void php_natsort(INTERNAL_FUNCTION_PARAMETERS, int fold_case) /* {{{ */
{
    zval *array;
    if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "a", &array) == FAILURE) {
        return;
    }
    if (fold_case) {
        if (zend_hash_sort(Z_ARRVAL_P(array), zend_qsort, php_array_natural_case_compare, 0 TSRMLS_CC) == FAILURE) {
            return;
        }
    } else {
        if (zend_hash_sort(Z_ARRVAL_P(array), zend_qsort, php_array_natural_compare, 0 TSRMLS_CC) == FAILURE) {
            return;
        }
    }
    RETURN_TRUE;
}
/* }}} */
/* {{{ proto void natsort(array &array_arg)
Sort an array using natural sort */
php_FUNCTION(natsort)
{
    php_natsort(INTERNAL_FUNCTION_PARAM_PASSTHRU, 0);
}
/* }}} */

雖然是第一次查看php的內核代碼,不過憑借多年看代碼的經驗,還是很容易找到這個自然排序算法的核心就是函數:strnatcmp_ex(位于ext/standard/strnatcmp.c文件中)。

php技術php natsort內核函數淺析第1/2頁,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 四虎永久免费在线观看 | 亚洲一区二区三区精品国产 | 黄 色 免 费 网站在线观看 | 最新国产区 | 国产成人黄网址在线视频 | 欧美最猛性xxxxx黑人巨 | 精品伊人久久大线蕉色首页 | 一区二区三区四区日韩 | 国产精品福利在线 | 91精品全国免费观看含羞草 | 免费国产最新进精品视频 | 天天做.天天爱.天天综合网 | 亚洲视频三区 | 天天摸天天看天天爽 | 女人的天堂网站 | 狠狠色成人综合首页 | 激情欧美一区二区三区 | 成人精品亚洲人成在线 | 日本网络视频www色高清免费 | 色在线免费视频 | 亚洲一区www | 337p亚洲精品色噜噜狠狠 | 亚洲精品亚洲人成在线播放 | 国产精品色综合久久 | 色综合久久中文色婷婷 | 色婷婷色婷婷 | 韩国亚洲伊人久久综合影院 | 91精品福利在线观看 | 久久精品这里热有精品2015 | 精品国产夜色在线 | 国产成人+亚洲欧洲 | 一区视频 | 日本三级成人中文字幕乱码 | 亚洲精品美女久久久久网站 | 日本人乱人乱亲乱色视频观看 | 香蕉成人在线 | 丁香激情六月天 | 伊人影院在线观看视频 | 四虎永久网址在线观看 | 99久久精品99999久久 | 成年网站视频在线观看 |