首頁  >  文章  >  後端開發  >  淺談PHP源碼十九:關於array_file,range函數

淺談PHP源碼十九:關於array_file,range函數

不言
不言原創
2018-06-28 17:41:161924瀏覽

這篇文章主要介紹了關於淺談PHP源碼十九:關於array_file,range函數,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下

淺談PHP原始碼十九:關於array_file,range函數

array_fill
(PHP 4 >= 4.2.0, PHP 5)

array_fill — 以給定的值填入陣列
說明
array array_fill ( int start_index, int num, mixed value )

array_fill() 用value 參數的值將一個陣列填入num 個項目,而鍵名稱由start_index 參數指定的開始。注意 num 必須是大於零的數值,否則 PHP 會發出警告。

對於參數start_index,只能是字串,整形,浮點型
其原始碼如下:

switch (Z_TYPE_PP(start_key)) {case IS_STRING:case IS_LONG:case IS_DOUBLE:
    .......    convert_to_long_ex(start_key);
    ......}

程式先賦值給return_value第一個值,然後循環num – 1次: 為這個值加上refcount,並將它加到return_value的Hash Table中

range
(PHP 3 >= 3.0.8, PHP 4, PHP 5)

# range — 建立一個包含指定範圍單元的陣列
說明
array range ( mixed low, mixed high [, number step] )

range() 傳回數組中從low 到high 的單元,包括它們本身。如果 low > high,則序列將從 high 到 low。

新參數: 可選的 step 參數是 PHP 5.0.0 新加的。

如果給了 step 的值,它將被當作單元之間的步進值。 step 應該為正值。如果未指定,step 則預設為 1。

從程式碼可以看出,本函數只支援字元數組,浮點數數組和整形數組,並且支援遞增和遞減兩種形式(在版本4.0.1之後才有)
以字元數組為例:

 if (Z_TYPE_P(zlow) == IS_STRING && Z_TYPE_P(zhigh) == IS_STRING && Z_STRLEN_P(zlow) >= 1 && Z_STRLEN_P(zhigh) >= 1) {
    int type1, type2;
    unsigned char *low, *high;
    long lstep = (long) step; 
    type1 = is_numeric_string(Z_STRVAL_P(zlow), Z_STRLEN_P(zlow), NULL, NULL, 0);
    type2 = is_numeric_string(Z_STRVAL_P(zhigh), Z_STRLEN_P(zhigh), NULL, NULL, 0);
    if (type1 == IS_DOUBLE || type2 == IS_DOUBLE || is_step_double) {
        goto double_str;
    } else if (type1 == IS_LONG || type2 == IS_LONG) {
        goto long_str;
    }
    convert_to_string(zlow);    //    转化为字符串,此函数的实现在zend_operators.c的536行:ZEND_API void _convert_to_string(zval *op ZEND_FILE_LINE_DC)
    convert_to_string(zhigh);
    low = (unsigned char *)Z_STRVAL_P(zlow);    //    当所给字符串长度大于1时,取第一个字符
    high = (unsigned char *)Z_STRVAL_P(zhigh);     if (*low > *high) { //    递减数组
    if (lstep <= 0) {
        err = 1;
        goto err;
    }
    for (; *low >= *high; (*low) -= (unsigned int)lstep) {
        add_next_index_stringl(return_value, low, 1, 1);
        if (((signed int)*low - lstep) < 0) {
            break;
        }
    }
    } else if (*high > *low) { //    递增数组
    if (lstep <= 0) {
        err = 1;
        goto err;
    }
    for (; *low <= *high; (*low) += (unsigned int)lstep) {
        add_next_index_stringl(return_value, low, 1, 1);
        if (((signed int)*low + lstep) > 255) {    //    只支持ASCII的255个字符
            break;
        }
    }
    } else {    //    开始和结束相等,则只返回包含一个元素的数组
        add_next_index_stringl(return_value, low, 1, 1);}

對於浮點型和整形的處理基本上類似,只有寫入Hash Table的方法不同

浮點型用的是add_next_index_double
整形用的是add_next_index_long

以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!

相關推薦:

淺談PHP源碼十八:關於array_diff_key,array_diff_assoc,array_udiff_assoc 函數

淺談PHP原始碼十六:關於array_count_values函數

以上是淺談PHP源碼十九:關於array_file,range函數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn