我的c基础不是很好,还请知道的能详解一下,谢谢
如果我直接使用类似如下的代码,就会出segfault错误
char* ret = "hello world";
RETURN_STRINGL(ret, strlen(ret), 0);
无论ret是直接写字符串,还是先初始化成char[100]这样,都不行
但是只要将程序稍加改进使用动态分配内存就没事:
char* hello = "hello world";
int len = strlen(hello);
char* ret = (char*)emalloc(len);
memcpy(ret, hello, len);
RETURN_STRINGL(ret, len, 0);
补充一句:后来发现RETURN_STRINGL的第三个参数改成1也不会有越界访问错误了
这个问题的实质是:
php本身是类型安全的脚本语言,对于RETURN_STRINGL或是RETURN_STRING返回的字符串,php会在适当的时候free掉,所以程序员要保证返回的字符串在堆里,能够free掉,这就是为什么动态分配就没事的原因。而:
char* ret = "hello world";
RETURN_STRINGL(ret, strlen(ret), 0);
这是直接返回了一个静态字符串,导致php在free这个字符串的时候出错。
RETURN_STRINGL和RETURN_STRING最后一个参数,如果是1,表示对第一个参数中的字符串在堆里复制一份返回。这就是为什么最后一个参数等于1的时候,程序正常的原因。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。