Maison >développement back-end >tutoriel php >Une brève discussion du code source PHP quinze : à propos de la fonction array_walk

Une brève discussion du code source PHP quinze : à propos de la fonction array_walk

不言
不言original
2018-06-28 17:28:331671parcourir

Cet article présente principalement la brève discussion sur le code source PHP 15 : Concernant la fonction array_walk, elle a une certaine valeur de référence. Maintenant, je la partage avec vous. Les amis dans le besoin peuvent s'y référer

Un bref. discussion sur le code source PHP 10 Cinq : À propos de la fonction array_walk

array_walk

(PHP 3 >= 3.0.3, PHP 4, PHP 5)
array_walk — Appliquer la fonction utilisateur à chaque membre du tableau
Description

bool array_walk (array &array, callback funcname [, Mixed userdata] )

Renvoie TRUE en cas de succès et FALSE en cas d'échec.
Appliquez la fonction définie par l'utilisateur funcname à chaque cellule du tableau. Généralement, funcname accepte deux paramètres. La valeur du paramètre array est utilisée comme première et le nom de la clé est utilisé comme second. Si l'argument facultatif userdata est fourni, il sera transmis comme troisième argument au rappel funcname.
Si la fonction funcname nécessite plus d'arguments que ceux indiqués, une erreur de niveau E_WARNING sera générée à chaque fois que array_walk() appelle funcname. Ces avertissements peuvent être supprimés en faisant précéder l'appel à array_walk() de l'opérateur d'erreur @ de PHP, ou en utilisant error_reporting().
Remarque : si funcname doit opérer directement sur les valeurs du tableau, spécifiez le premier paramètre de funcname comme référence. Ainsi, toute modification apportée à ces cellules modifiera également le tableau d'origine lui-même.
Remarque : transmettre le nom de la clé et les données utilisateur dans funcname est une nouveauté dans PHP 4.0.

array_walk() n'est pas affecté par le pointeur de tableau interne du tableau. array_walk() parcourra tout le tableau quelle que soit la position du pointeur. (Cela est dû au fait que le programme réinitialise le pointeur de la table de hachage où se trouve le tableau au début du parcours du tableau)
L'utilisateur ne doit pas modifier le tableau lui-même dans la fonction de rappel. Par exemple, ajouter/supprimer des unités, supprimer des unités, etc. Si le tableau sur lequel array_walk() agit change, le comportement de cette fonction est indéfini et imprévisible.
Description de l'implémentation du programme :
Le dernier appel de l'extension est la fonction php_array_walk :

   static int php_array_walk(HashTable *target_hash, zval **userdata, int recursive TSRMLS_DC)

Lorsque récursive == 0, cette fonction implémente la fonction array_walk

Lorsque récursive == 1, cette fonction est l'implémentation de la fonction array_walk_recursive

Dans le code source, le programme parcourra l'intégralité du tableau et, pour chaque élément du tableau, effectuera des appels de fonction pertinents en fonction de la fonction transmise
L'appel de fonction est le suivant :

fci.size = sizeof(fci);
            fci.function_table = EG(function_table);
            fci.function_name = *BG(array_walk_func_name);
            fci.symbol_table = NULL;
            fci.object_pp = NULL;
            fci.retval_ptr_ptr = &retval_ptr;
            fci.param_count = userdata ? 3 : 2;
            fci.params = args;
            fci.no_separation = 0;             /* Call the userland function */
            if (zend_call_function(&fci, &array_walk_fci_cache TSRMLS_CC) == SUCCESS) {

Une structure est utilisée dans cet appel de fonction. Les commentaires personnels sont les suivants :

 typedef struct _zend_fcall_info {
 size_t size;    //    整个结构体的长度,等于sizeof(此函数体的变量)
 HashTable *function_table;    //    executor_globals.function_table
 zval *function_name;    //    函数名 
 HashTable *symbol_table;
 zval **retval_ptr_ptr;        //    函数的返回值
 zend_uint param_count;    //    参数个数
 zval ***params;            //    所调用函数的参数
 zval **object_pp;        //    用于对象的方法调用时,存储对象
 zend_bool no_separation;    //    是否清空参数所在的栈} zend_fcall_info;

Ce qui précède sont des notes personnelles. y a-t-il des erreurs, corrigez-moi !

EOF

Ce qui précède est l'intégralité du contenu de cet article. J'espère qu'il sera utile à l'étude de chacun. Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois !

Recommandations associées :

Une brève discussion du code source PHP 14 : À propos de la fonction array_combine

Une brève discussion de Code source PHP 13 : À propos de array_change_key_case, introduction à array_chunk

Une brève discussion sur le code source PHP 12 : À propos de return_value Valeur de retour

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn