在一个扩展模块里,类之间方法的调用,上面第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"
在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){
函数原型:
在 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;