为什么宏 "ZVAL_COPY_VALUE(z,v)" 似乎在 PHP Internal 中意外工作?
Why the macro "ZVAL_COPY_VALUE(z,v)" seems to work unexpectedly in PHP Internal?
我的问题是关于哈希表的:
调试的PHP VERSION是PHP-7.0.12,我找不到zval的str成员在宏中更新的位置"ZVAL_COPY_VALUE(z, v)" 当我添加一个新字符串时,但是它确实通过 GDB 跟踪宏上下文更新成功,也就是说,zval 的 [= Bucket 结构中的 19=]str 成员确实获得了字符串地址。
展开宏,最终得到代码如下:
zval *_z1 = z;
const zval *_z2 = v;
zend_refcounted *_gc = (*_z2).value.counted
uint32_t _t = (*_z2).u1.type_info;
uint32_t _w2 = _z2->value.ww.w2;
(*_z1).value.counted = _gc;
_z1->value.ww.w2 = _w2;
(*_z1).u1.type_info = _t;
zend_value
是联合类型,也就是说所有的成员共享同一个起始地址。复制 value.counted
和 value.ww.w2
会复制整个 zend_value
结构。当时实际使用的是哪个成员并不重要。
我的问题是关于哈希表的:
调试的PHP VERSION是PHP-7.0.12,我找不到zval的str成员在宏中更新的位置"ZVAL_COPY_VALUE(z, v)" 当我添加一个新字符串时,但是它确实通过 GDB 跟踪宏上下文更新成功,也就是说,zval 的 [= Bucket 结构中的 19=]str 成员确实获得了字符串地址。
展开宏,最终得到代码如下:
zval *_z1 = z;
const zval *_z2 = v;
zend_refcounted *_gc = (*_z2).value.counted
uint32_t _t = (*_z2).u1.type_info;
uint32_t _w2 = _z2->value.ww.w2;
(*_z1).value.counted = _gc;
_z1->value.ww.w2 = _w2;
(*_z1).u1.type_info = _t;
zend_value
是联合类型,也就是说所有的成员共享同一个起始地址。复制 value.counted
和 value.ww.w2
会复制整个 zend_value
结构。当时实际使用的是哪个成员并不重要。