php7 ZEND_BEGIN_ARG_INFO_EX, ZEND_ARG_INFO分析

我们在写扩展的时候很常见的这样的宏,就比如swoole扩展中:

  ZEND_BEGIN_ARG_INFO_EX(arginfo_swoole_server_listen, 0, 0, 3)
    ZEND_ARG_INFO(0, host)
    ZEND_ARG_INFO(0, port)
    ZEND_ARG_INFO(0, sock_type)
  ZEND_END_ARG_INFO()

这个宏组合是用来定义函数的参数,我们不妨去跟下ZEND_BEGIN_ARG_INFO_EX 与ZEND_END_ARG_INFO的定义。
定义在zend_API.h文件中,ZEND_BEGIN_ARG_INFO_EX的定义为:

#define ZEND_BEGIN_ARG_INFO_EX(name, _unused, return_reference, required_num_args)  \
   static const zend_internal_arg_info name[] = { \
   {(const char*)(zend_uintptr_t)(required_num_args), 0, return_reference, 0 },

ZEND_END_ARG_INFO的定义为:

 #define ZEND_ARG_INFO(pass_by_ref, name){ #name, 0, pass_by_ref, 0},

那么组合起来变成c代码就是

static const zend_internal_arg_info arginfo_swoole_server_listen[] = { \
   {3, 0, 0, 0 },
   { host, 0, 0, 0},
   { port, 0, 0, 0},
   { sock_type, 0, 0, 0},
}

现在看来就是定义了一个zend_internal_arg_info结构数组,在zend/zend_compile.h文件中定义:

typedef struct _zend_internal_arg_info {
    const char *name;      //参数名称
    const char *class_name;  //当参数类型为类时,指定类的名称
    zend_uchar type_hint;    //参数类型是否为数组
    zend_uchar pass_by_reference;  //是否设置为引用,即&
    zend_bool allow_null;   //是否允许设置为空
    zend_bool is_variadic;//是否允许设置为空
} zend_internal_arg_info;

至此zend arg info相关的已经分析完毕

发表评论

电子邮件地址不会被公开。 必填项已用*标注