用c写php的扩展,遇到奇怪的问题,麻烦大家指点一下啊
PHP_FUNCTION(list_clean){
zval *z_array; /* 外部传入的数组 */
zval **z_item; /* 一级数组单元 */
zval **zz_item; /* 二级数组单元 */
int len, len1;
int i, i1;
int tag = 0;
if (FAILURE == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "a", &z_array)) {
return;
}
array_init(return_value);
/* 获取数组大小 */
len = zend_hash_num_elements(Z_ARRVAL_P(z_array));
/* 将数组的内部指针指向第一个单元 */
zend_hash_internal_pointer_reset(Z_ARRVAL_P(z_array));
for (i = 0; i < len; i ++) {
char* key;
int idx;
/* 获取当前数据 */
zend_hash_get_current_data(Z_ARRVAL_P(z_array), (void**) &z_item);
convert_to_array_ex(z_item);
if (zend_hash_get_current_key(Z_ARRVAL_P(z_array), &key, &idx, 0) == HASH_KEY_IS_STRING) {
/* KEY为字符串 */
return;
} else {
int breakTag = 0;
/* KEY为数字 */
zval *temp_value;
MAKE_STD_ZVAL(temp_value);
array_init(temp_value); /* 存储组成return_value的中间数组 */
len1 = zend_hash_num_elements(Z_ARRVAL_P(*z_item));
zend_hash_internal_pointer_reset(Z_ARRVAL_P(*z_item));
for(i1=0; i1<len1; i1++){
char* key1;
int idx1;
/* 获取当前数据 */
zend_hash_get_current_data(Z_ARRVAL_P(*z_item), (void**) &zz_item);
convert_to_string_ex(zz_item);
if (zend_hash_get_current_key(Z_ARRVAL_P(*z_item), &key1, &idx1, 0) == HASH_KEY_IS_STRING){
add_assoc_string(return_value, key1, Z_STRVAL_PP(zz_item), 1);
//add_next_index_string(return_value, Z_STRVAL_PP(zz_item), 1);
// add_next_index_string(return_value, key1, 1);
}else{
return;
}
zend_hash_move_forward(Z_ARRVAL_P(*z_item));
}
//add_index_zval(return_value, tag, temp_value);
tag++;
zval_ptr_dtor(&temp_value); /* 释放资源 */
}
/* 将数组中的内部指针向前移动一位 */
zend_hash_move_forward(Z_ARRVAL_P(z_array));
}
}用c定义了个叫list_clean的php函数,在php中写的测试代码如图:
当我注释掉46、48行,保留47行代码时,
测试结果如图:
说明Z_STRVAL_PP(zz_item)值是没问题的
当我注释掉46、47行,保留48行时,
测试结果如图:
说明索引key1也是没问题的
但当我保留46行,注释掉47、48行时
测试结果如图:
这时的结果就出问题了
有哪位大神能指点迷津卜/ I see,zval_ptr_dtor(&temp_value);用错了
页:
[1]