淺談PHP源碼十九:關(guān)于array_file,range函數(shù)
array_fill
(PHP 4 = 4.2.0, PHP 5)
array_fill — 用給定的值填充數(shù)組
說明
array array_fill ( int start_index, int num, mixed html' target='_blank'>value )
array_fill() 用 value 參數(shù)的值將一個(gè)數(shù)組填充 num 個(gè)條目,鍵名由 start_index 參數(shù)指定的開始。注意 num 必須是一個(gè)大于零的數(shù)值,否則 PHP 會(huì)發(fā)出一條警告。
對于參數(shù)start_index,只能是字符串,整形,浮點(diǎn)型
其源碼如下:
switch (Z_TYPE_PP(start_key)) {case IS_STRING:case IS_LONG:case IS_DOUBLE: ....... convert_to_long_ex(start_key); ......}
程序首先賦值給return_value第一個(gè)值,然后循環(huán)num – 1次: 給這個(gè)值添加refcount,并將它添加到return_value的Hash Table中
range
(PHP 3 = 3.0.8, PHP 4, PHP 5)
range — 建立一個(gè)包含指定范圍單元的數(shù)組
說明
array range ( mixed low, mixed high [, number step] )
range() 返回?cái)?shù)組中從 low 到 high 的單元,包括它們本身。如果 low high,則序列將從 high 到 low。
新參數(shù): 可選的 step 參數(shù)是 PHP 5.0.0 新加的。
如果給出了 step 的值,它將被作為單元之間的步進(jìn)值。step 應(yīng)該為正值。如果未指定,step 則默認(rèn)為 1。
從代碼可以看出,本函數(shù)僅支持字符數(shù)組,浮點(diǎn)數(shù)組和整形數(shù)組,并且支持遞增和遞減兩種形式(在版本4.0.1之后才有)
以字符數(shù)組為例:
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); // 轉(zhuǎn)化為字符串,此函數(shù)的實(shí)現(xiàn)在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); // 當(dāng)所給字符串長度大于1時(shí),取第一個(gè)字符 high = (unsigned char *)Z_STRVAL_P(zhigh); if (*low *high) { // 遞減數(shù)組 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) { // 遞增數(shù)組 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個(gè)字符 break; } else { // 開始和結(jié)束相等,則只返回包含一個(gè)元素的數(shù)組 add_next_index_stringl(return_value, low, 1, 1);}
對于浮點(diǎn)型和整形的處理基本類似,只有寫入Hash Table的方法不同
浮點(diǎn)型用的是add_next_index_double
整形用的是add_next_index_long
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,更多相關(guān)內(nèi)容請關(guān)注PHP !
相關(guān)推薦:
淺談PHP源碼十八:關(guān)于array_diff_key,array_diff_assoc,array_udiff_assoc 函數(shù)
淺談PHP源碼十六:關(guān)于array_count_values函數(shù)
以上就是淺談PHP源碼十九:關(guān)于array_file,range函數(shù)的詳細(xì)內(nèi)容,PHP教程
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時(shí)間聯(lián)系我們修改或刪除,多謝。
|
新聞熱點(diǎn)
疑難解答
圖片精選