在一个扩展模块里,类之间方法的调用,上面第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;