首頁 >後端開發 >php教程 >淺談PHP原始碼十八:關於array_diff_key,array_diff_assoc,array_udiff_assoc 函數

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

不言
不言原創
2018-06-28 17:37:492474瀏覽

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

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

【array_diff_key】

#(PHP 5 >= 5.1.0RC1)
array_diff_key # 使用鍵名比較計算計算數組的數字差集
說明

array array_diff_key ( array array1, array array2 [, array ...] )

array_diff_key() 傳回一個數組,該數組包含了所有出現在array1 中但是未出現在任何其它參數數組中的鍵名的值。注意關聯關係保留不變。

【array_diff_assoc】

(PHP 4 >= 4.3.0, PHP 5)
array_diff_assoc — 帶索引檢查計算數組的差集
說明

array array_diff_assoc ( array array1, array array2 [, array ...] )

array_diff_assoc() 傳回一個數組,該數組包含了所有在array1 中但是不在任何其它參數數組中的值。注意和 array_diff() 不同的是鍵名也用於比較。

之所以把這三個函數放在一起是因為他們呼叫的最後是一個函數:php_array_diff_key
【array_diff_uassoc】

(PHP 5)
array_diff_uassoc — 用用戶提供的回呼函數做索引檢查來計算數組的差集
說明

array array_diff_uassoc ( array array1, array array2 [, array ..., callback key_compare_func] )

array_diff_uassoc( ) 傳回一個數組,該數組包括了所有在array1 中但是不在任何其它參數數組中的值。

這三個函數呼叫php-array_diff_key的方式如下:

  array_diff_key:         php_array_diff_key(INTERNAL_FUNCTION_PARAM_PASSTHRU, DIFF_COMP_DATA_NONE);array_diff_assoc:      php_array_diff_key(INTERNAL_FUNCTION_PARAM_PASSTHRU, DIFF_COMP_DATA_INTERNAL);array_udiff_assoc:    php_array_diff_key(INTERNAL_FUNCTION_PARAM_PASSTHRU, DIFF_COMP_DATA_USER);

 其中參數的巨集定義如下:

  #define INTERNAL_FUNCTION_PARAM_PASSTHRU ht, return_value, return_value_ptr, this_ptr, return_value_used TSRMLS_CC #define DIFF_COMP_DATA_NONE    -1#define DIFF_COMP_DATA_INTERNAL 0#define DIFF_COMP_DATA_USER     1

php_array_diff_key函數首先要根據傳入的data_compare_type(即上面定義的三個巨集),判斷所要使用的比較函數,然後遍歷第一個數組,針對每一個元素與其它數組比較,看其它數字是否存在

如果存在則刪
針對此函數的原始碼做一個註解性的說明:

 for (i = 0; i < argc; i++) {
        if (Z_TYPE_PP(args[i]) != IS_ARRAY) {
            php_error_docref(NULL TSRMLS_CC, E_WARNING, "Argument #%d is not an array", i + 1);
            RETVAL_NULL();
            goto out;    //    goto语句,这个貌似一般是高手用的,嘿嘿
        }
    } 
    array_init(return_value);    //    返回数组初始化,初始化存储此数组的Hash Table     for (p = Z_ARRVAL_PP(args[0])->pListHead; p != NULL; p = p->pListNext) {    //    遍历第一个参数包含的双向链表
        if (p->nKeyLength == 0) {    //    数组索引为数字
            ok = 1;
            for (i = 1; i < argc; i++) {    //    对其它的数组进行判断
                if (zend_hash_index_find(Z_ARRVAL_PP(args[i]), p->h, (void**)&data) == SUCCESS &&
                    (!diff_data_compare_func ||
                     diff_data_compare_func((zval**)p->pData, data TSRMLS_CC) == 0)) {
                    ok = 0;
                    break;
                }
            }
            if (ok) {    在第一个数组中,不在其它数组中                (*((zval**)p->pData))->refcount++;
                zend_hash_index_update(Z_ARRVAL_P(return_value), p->h, p->pData, sizeof(zval*), NULL);
            }
        } else {    //    索引为字符串
            ok = 1;
            for (i = 1; i < argc; i++) {
                if (zend_hash_quick_find(Z_ARRVAL_PP(args[i]), p->arKey, p->nKeyLength, p->h, (void**)&data) == SUCCESS &&
                    (!diff_data_compare_func ||
                     diff_data_compare_func((zval**)p->pData, data TSRMLS_CC) == 0)) {
                    ok = 0;
                    break;
                }
            }
            if (ok) {
                (*((zval**)p->pData))->refcount++;
                zend_hash_quick_update(Z_ARRVAL_P(return_value), p->arKey, p->nKeyLength, p->h, p->pData, sizeof(zval*), NULL);
            }
        }
    }

關於比較函數:

DIFF_COMP_DATA_NONE參數對應的是NULL,即不存在比較,使用索引查找就可以了
DIFF_COMP_DATA_INTERNAL參數對應的是zval_compare,也就是索引和值都會比較
DIFF_COMP_DATA_USER參數對應的是zval_user_compare,也就是用戶自訂的函數

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

相關推薦:

淺談PHP原始碼十七:關於array_diff,array_udiff,array_diff_ukey,array_diff_uassoc,array_udiff_uassoc的介紹

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

#淺聊PHP原始碼十五:關於array_walk函數

##############################################

以上是淺談PHP原始碼十八:關於array_diff_key,array_diff_assoc,array_udiff_assoc 函數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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