Heim  >  Artikel  >  Backend-Entwicklung  >  Eine kurze Diskussion des PHP-Quellcodes 18: Über die Funktionen array_diff_key, array_diff_assoc, array_udiff_assoc

Eine kurze Diskussion des PHP-Quellcodes 18: Über die Funktionen array_diff_key, array_diff_assoc, array_udiff_assoc

不言
不言Original
2018-06-28 17:37:492402Durchsuche

Dieser Artikel stellt hauptsächlich den PHP-Quellcode 18 vor: Über die Funktionen array_diff_key, array_diff_assoc, array_udiff_assoc, die einen bestimmten Referenzwert haben. Jetzt kann ich sie mit Ihnen teilen.

Apropos PHP-Quellcode 18: Über die Funktionen array_diff_key, array_diff_assoc, array_udiff_assoc

[array_diff_key]

(PHP 5 >= 5.1.0RC1)
array_diff_key – Verwenden Sie den Schlüsselnamenvergleich, um die Array-Differenz zu berechnen set
Beschreibung

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

array_diff_key() gibt ein Array zurück, das alle Vorkommen in array1 enthält. Aber der Wert des Der Schlüssel erscheint in keinem anderen Parameterarray. Beachten Sie, dass die Beziehung unverändert bleibt.

[array_diff_assoc]

(PHP 4 >= 4.3.0, PHP 5)
array_diff_assoc — Berechnen Sie die Differenz von Arrays mit Indexprüfung
Beschreibung

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

array_diff_assoc() gibt ein Array zurück, das alle Werte in array1, aber nicht in einem anderen Parameterarray enthält. Beachten Sie, dass im Gegensatz zu array_diff() auch Schlüsselnamen zum Vergleich verwendet werden.

Der Grund, warum diese drei Funktionen zusammengefasst werden, liegt darin, dass die letzte Funktion, die sie aufrufen, eine Funktion ist: php_array_diff_key
[array_diff_uassoc]

(PHP 5)
array_diff_uassoc – Benutzer verwenden Die bereitgestellte Rückruffunktion führt eine Indexprüfung durch, um die Differenzmenge des Arrays zu berechnen.
Beschreibung

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

array_diff_uassoc( ) gibt ein Array zurück, das alle Werte in Array1 enthält, die sich in keinem anderen Parameter-Array befinden.

Die Art und Weise, wie diese drei Funktionen php-array_diff_key aufrufen, ist wie folgt:

  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);

Die Makrodefinition der Parameter lautet wie folgt:

  #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

Die Funktion php_array_diff_key muss zuerst sein Bestimmen Sie basierend auf dem eingehenden data_compare_type (d. h. den drei oben definierten Makros) die zu verwendende Vergleichsfunktion, durchlaufen Sie dann das erste Array und vergleichen Sie jedes Element mit anderen Arrays, um zu sehen, ob andere Zahlen vorhanden sind

Wenn sie existieren, Löschen Sie sie
für Kommentierte Erklärung des Quellcodes dieser Funktion:

 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);
            }
        }
    }

Über die Vergleichsfunktion:

Der Parameter DIFF_COMP_DATA_NONE entspricht NULL, dh es gibt keinen Vergleich, sondern wird einfach verwendet Indexsuche
DIFF_COMP_DATA_INTERNAL Der Parameter entspricht zval_compare, dh der Index und der Wert werden verglichen
Der DIFF_COMP_DATA_USER-Parameter entspricht zval_user_compare, einer benutzerdefinierten Funktion

Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, er wird für das Lernen aller nützlich sein. Wenn Sie Hilfe benötigen, schauen Sie sich bitte die chinesische PHP-Website an, um weitere verwandte Inhalte zu erhalten!

Verwandte Empfehlungen:

Eine kurze Diskussion des PHP-Quellcodes siebzehn: Einführung in array_diff, array_udiff, array_diff_ukey, array_diff_uassoc, array_udiff_uassoc

Eine kurze Diskussion zum PHP-Quellcode 16: Über die Funktion array_count_values ​​​​

Eine kurze Diskussion zum PHP-Quellcode 15: Über die Funktion array_walk

Das obige ist der detaillierte Inhalt vonEine kurze Diskussion des PHP-Quellcodes 18: Über die Funktionen array_diff_key, array_diff_assoc, array_udiff_assoc. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn