Dieser Artikel stellt hauptsächlich den PHP-Quellcode 4 vor: In Bezug auf die Zählfunktion hat er einen bestimmten Referenzwert. Jetzt können Freunde in Not darauf verweisen.
In einigen Interviews oder Prüfungen Ich sehe oft die Zählfunktion, also haben wir uns das genauer angesehen
Für die Zählverarbeitung von Nicht-Arrays
Sie können es im Code sehen
PHP_FUNCTION(count){ zval *array; long mode = COUNT_NORMAL; if (zend_parse_parameters (ZEND_NUM_ARGS() TSRMLS_CC, "z|l", &array, &mode) == FAILURE) return; switch (Z_TYPE_P(array)) { case IS_NULL: // 空值处理 RETURN_LONG(0); break; case IS_ARRAY: // 处理数组,包括其是递归 RETURN_LONG (php_count_recursive (array, mode TSRMLS_CC)); break; case IS_OBJECT: { #ifdef HAVE_SPL /* it the object implements Countable we call its count() method */ zval *retval; if (Z_OBJ_HT_P(array)->get_class_entry && instanceof_function(Z_OBJCE_P(array), spl_ce_Countable TSRMLS_CC)) { zend_call_method_with_0_params(&array, NULL, NULL, "count", &retval); if (retval) { convert_to_long_ex(&retval); RETVAL_LONG(Z_LVAL_P(retval)); zval_ptr_dtor(&retval); } return; } #endif /* if not we return the number of properties (not taking visibility into account) */ if (Z_OBJ_HT_P(array)->count_elements) { RETVAL_LONG(1); if (SUCCESS == Z_OBJ_HT(*array)->count_elements(array, &Z_LVAL_P(return_value) TSRMLS_CC)) { return; } } } default: // 其它情况,如考试中常见的字符串等 RETURN_LONG(1); break; }}
Es wird im Handbuch erklärt:
Wenn SPL für Objekte installiert ist, kann diese Funktion count() aufrufen, indem die Countable-Schnittstelle implementiert wird. Diese Schnittstelle verfügt nur über eine Methode, count(), die den Rückgabewert der Funktion count() zurückgibt.
Für die Statistiken der Array-Länge wird, wenn der Modus den Standardwert (0) verwendet, nur die Länge des Arrays der ersten Dimension angezeigt
Der Code lautet wie folgt
$arr = array(1, 2, 3); $arr2 = array($arr, $arr); echo count($arr2), '<br />'; echo count($arr2, 1); /* 输出结果:28*/
Wenn nur die erste Dimension wird angezeigt Array, dann wird direkt das nNumOfElements-Attribut der HashTable zurückgegeben, die das Array speichert
Der Implementierungscode lautet:
// php_count_recursive函数 array.c 251行cnt = zend_hash_num_elements(Z_ARRVAL_P(array)); ZEND_API int zend_hash_num_elements(HashTable *ht){ IS_CONSISTENT(ht); return ht->nNumOfElements;}
Wenn Sie einige einfache Operationen von HashTable direkt ausführen möchten, klicken Sie auf das einfache Beispiel von HashTable im PHP-Quellcode
Wenn Sie sehen möchten, wie Arrays gespeichert oder durchlaufen werden, klicken Sie auf Brother Birds ausführliches Verständnis von PHP-Arrays (Durchlaufreihenfolge)
Wenn Rekursion wird gestartet, verwenden Sie count($arr, 1)
Dann ruft das Programm rekursiv die Funktion php_count_recursive auf
Für HashTable durchläuft das Programm die doppelt verknüpfte Liste, die dieses dimensionale Array enthält, und durchläuft dann rekursiv die gespeicherten pData in jedem Knoten, bis alle Knoten durchlaufen sind
[Gefühl]
HashTable ist sehr leistungsfähig. Wenn Sie die Länge eines Arrays berechnen oder die Zählfunktion aufrufen möchten, müssen Sie das Rad neu erfinden undankbare Aufgabe!
Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, dass er für das Studium aller hilfreich ist. Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website.
Verwandte Empfehlungen:
Eine kurze Diskussion über PHP-Quellcode drei: Über die Funktionen strrchr, strstr, stristr
Eine kurze Diskussion zum PHP-Quellcode eins: Explode- und Implode-Funktionen
Das obige ist der detaillierte Inhalt vonEine kurze Diskussion zum PHP-Quellcode 4: Über die Zählfunktion. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!