c python 内存冲突_C/C++ extended python时一种常见的内存泄漏

PyObject *dic = PyDict_New();

iret = PyDict_SetItem(dic, Py_BuildValue("s","xxxxxx"),Py_BuildValue("s"), "Hello xxxx");

这样就会出现内存泄漏!

正确的写法应该是这样:

PyObject *dic = PyDict_New();

PyObject *obj1 = Py_BuildValue("s","xxxxxx");

PyObject *obj2 = Py_BuildValue("s", "Hello xxxx");

iret = PyDict_SetItem(dic, obj1, obj2);

Py_XDECREF(obj1);

Py_XDECREF(obj2);

还有一种写法就会导致coredump

PyObject *dic = PyDict_New();

PyObject *obj1 = Py_BuildValue("s","xxxxxx");

PyObject *obj2 = Py_BuildValue("s", "Hello xxxx");

Py_XDECREF(obj1);

Py_XDECREF(obj2);

iret = PyDict_SetItem(dic, obj1, obj2);

其实想想是正确的行为: python obj是通过reference来控制生命周期的。如果一次c/++ API某些obj引用 计数不为0就返回了。这些对象就会一直存在python虚拟机里面。python虚拟机 本来也不该回收他们。

最后一种情况就更好理解了,访问一个已经回收的地址当然就会coredump咯

顺带说说测试办法: 1.测试内存泄漏就是调大返回数据,for多次调用。top看见内存在不停的 增加就是内存泄漏了。

长时间运行,覆盖测试可以发现这个问题。

Date: 2012-06-29 00:02:19 CST

HTML generated by org-mode 6.33x in emacs 23

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值