La définition d'une fonction est simplement un processus d'enregistrement du nom de la fonction dans la liste des fonctions.
1. Paramètres de la fonction personnalisée
Nous savons que la vérification des paramètres de la fonction est implémentée via la fonction zend_do_receive_arg Dans cette fonction, le code clé du. Les paramètres sont les suivants :CG(active_op_array)->arg_info = erealloc(CG(active_op_array)->arg_info, sizeof(zend_arg_info)*(CG(active_op_array)->num_args)); cur_arg_info = &CG(active_op_array)->arg_info[CG(active_op_array)->num_args-1]; cur_arg_info->name = estrndup(varname->u.constant.value.str.val, varname->u.constant.value.str.len); cur_arg_info->name_len = varname->u.constant.value.str.len; cur_arg_info->array_type_hint = 0; cur_arg_info->allow_null = 1; cur_arg_info->pass_by_reference = pass_by_reference; cur_arg_info->class_name = NULL; cur_arg_info->class_name_len = 0;
typedef struct _zend_arg_info { const char *name; /*参数的名称*/ zend_uint name_len; /*参数名称的长度*/ const char *class_name; /* 类名*/ zend_uint class_name_len; /*类名长度*/ zend_bool array_type_hint; /*数组类型提示*/ zend_bool allow_null; /*是否允许为NULLͺ*/ zend_bool pass_by_reference; /*是否引用传递*/ zend_bool return_reference; int required_num_args; } zend_arg_info;
CG(active_op_array)->num_args++;
cur_arg_info = &CG(active_op_array)->arg_info[CG(active_op_array)->num_args-1];
paramètres variables . Nous utiliserons actuellement les fonctions func_num_args et func_get_args. Elles existent en tant que fonctions internes. Retrouvez donc l'implémentation de ces deux fonctions dans le fichier Zendzend_builtin_functions.c. Regardons d'abord l'implémentation de la fonction func_num_args. Le code est le suivant :
/* {{{ proto int func_num_args(void) Get the number of arguments that were passed to the function */ ZEND_FUNCTION(func_num_args) { zend_execute_data *ex = EG(current_execute_data)->prev_execute_data; if (ex && ex->function_state.arguments) { RETURN_LONG((long)(zend_uintptr_t)*(ex->function_state.arguments)); } else { zend_error(E_WARNING, "func_num_args(): Called from the global scope - no function context"); RETURN_LONG(-1); } } /* }}} */
zend_execute_data *ex = EG(current_execute_data)->prev_execute_data;
/* {{{ proto int count(mixed var [, int mode]) Count the number of elements in a variable (usually an array) */ PHP_FUNCTION(count) { zval *array; long mode = COUNT_NORMAL; if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z|l", &array, &mode) == FAILURE) { return; } ... //省略 }
#define ZEND_NUM_ARGS() (ht)
#define INTERNAL_FUNCTION_PARAMETERS int ht, zval *return_value, zval **return_value_ptr, zval *this_ptr, int return_value_used TSRMLS_DC
ZEND_API int zend_parse_parameters(int num_args TSRMLS_DC, char *type_spec, ...)
chaîne formatée qui spécifie le format de sortie dans printf.
Les paramètres restants sont des pointeurs vers des variables que nous utilisons pour recevoir les valeurs des paramètres PHP. zend_parse_parameters() convertit le type de paramètre autant que possible lors de l'analyse des paramètres, afin de garantir que nous pouvons toujours obtenir le type de variable attenduCe 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!