在一个扩展模块里,类之间方法的调用,上面第7个有例子简介,就不多说了首先我们先创建play扩展模块,再创建adf扩展模块,最后创建udf扩展模块,我们要做到的是php -m中显示加载了play,我们可以调用adf类和udf类。
第一步: 在adf和udf类中各实现set get方法,然后初始化minit中的内容 运行成功后,将adf.c php_adf.h和udf.c php_udf.h拷入play文件中第二步修改play文件夹中的config.m4:if test -z "$PHP_DEBUG" ; then PHP_NEW_EXTENSION(play, play.c udf.c adf.c, $ext_shared,, -DZEND_ENABLE_STATIC_TSRMLS_CACHE=1)在play.c的MINIT函数中加上 ZEND_MODULE_STARTUP_N(udf) (INIT_FUNC_ARGS_PASSTHRU); ZEND_MODULE_STARTUP_N(adf) (INIT_FUNC_ARGS_PASSTHRU); 第三步执行 phpize ./configure --with-php-config=/usr/bin/php-config --enable-debug make && make install
在adf.c中加一个静态方法const zend_function_entry adf_functions[] = { PHP_ME(adf, __construct,NULL,ZEND_ACC_PUBLIC|ZEND_ACC_CTOR) PHP_ME(adf,set,global_setkey_arg,ZEND_ACC_PUBLIC) PHP_ME(adf,get,NULL,ZEND_ACC_PUBLIC) PHP_ME(adf,calladf,NULL,ZEND_ACC_PUBLIC|ZEND_ACC_STATIC) PHP_FE_END /* Must be the last line in adf_functions[] */ }; 加上这个一行 PHP_ME(adf,calladf,NULL,ZEND_ACC_PUBLIC|ZEND_ACC_STATIC) 再实现一个空方法 ZEND_METHOD(adf,calladf){ }
在udf.c 中定义了一个get方法,它用来调用adf.c中的calladf的静态方法ZEND_METHOD(udf,get){ //创建类实例 zval *object_name; //函数名i zval function_name; ZVAL_STRING(&function_name, "calladf"); //zend_call_method_with_0_params(object_name,adf_ce,NULL,"calladf",return_value); zend_call_method(object_name,adf_ce,NULL,"calladf",sizeof("calladf")-1,return_value,0,NULL,NULL); }
函数原型:在 Zend/zend_interfaces.下:#define zend_call_method_with_0_params(obj, obj_ce, fn_proxy, function_name, retval) \ zend_call_method(obj, obj_ce, fn_proxy, function_name, sizeof(function_name)-1, retval, 0, NULL, NULL) #define zend_call_method_with_1_params(obj, obj_ce, fn_proxy, function_name, retval, arg1) \ zend_call_method(obj, obj_ce, fn_proxy, function_name, sizeof(function_name)-1, retval, 1, arg1, NULL) #define zend_call_method_with_2_params(obj, obj_ce, fn_proxy, function_name, retval, arg1, arg2) \ zend_call_method(obj, obj_ce, fn_proxy, function_name, sizeof(function_name)-1, retval, 2, arg1, arg2) 上面三个调用下面的: ZEND_API zval* zend_call_method(zval *object_pp, zend_class_entry *obj_ce, zend_function **fn_proxy, const char *function_name, size_t function_name_len, zval *retval, int param_count, zval* arg1, zval* arg2); 上面调用zend_call_function 在Zend/zend_API.h下: ZEND_API int zend_call_function(zend_fcall_info *fci, zend_fcall_info_cache *fci_cache); typedef struct _zend_fcall_info { size_t size; HashTable *function_table; zval function_name; zend_array *symbol_table; zval *retval; zval *params; zend_object *object; zend_bool no_separation; uint32_t param_count; } zend_fcall_info;
- 请尊重本人劳动成功,可以随意转载但保留以下信息
- 作者:岁月经年
- 时间:2016年03月
- 首发: