免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3754 | 回复: 9
打印 上一主题 下一主题

[C] 求助:glib 2.40.2 疑似内存泄漏问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-12-18 16:55 |只看该作者 |倒序浏览
初次使用Glib,代码基本写完之后,顺手测试下,发现
GHashTable内存泄漏问题,不知是否使用方式不对?
另:g_key_file_new .. g_key_file_load_from_file ... g_key_file_free 同样问题。。

精简后最小测试代码如下:

#include <glib.h>
int main(int argc,char **argv){
        printf("glib version = %d.%d.%d\n",glib_major_version,glib_minor_version,glib_micro_version);
        GHashTable *h = g_hash_table_new(NULL,NULL);
        g_hash_table_destroy(h);
}

编译后运行之
valgrind --db-attach=yes --tool=memcheck --leak-check=full --show-leak-kinds=all ./test.bin

glib version = 2.40.2
==27702== HEAP SUMMARY:
==27702==     in use at exit: 2,076 bytes in 3 blocks
==27702==   total heap usage: 6 allocs, 3 frees, 2,260 bytes allocated
==27702==
==27702== 4 bytes in 1 blocks are still reachable in loss record 1 of 3
==27702==    at 0x4C2AB80: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==27702==    by 0x56B08CD: ??? (in /lib/x86_64-linux-gnu/libglib-2.0.so.0.4002.0)
==27702==    by 0x56B0D28: g_private_get (in /lib/x86_64-linux-gnu/libglib-2.0.so.0.4002.0)
==27702==    by 0x568A20C: g_slice_alloc (in /lib/x86_64-linux-gnu/libglib-2.0.so.0.4002.0)
==27702==    by 0x565E17D: g_hash_table_new_full (in /lib/x86_64-linux-gnu/libglib-2.0.so.0.4002.0)
==27702==    by 0x4019E0: do_test_ini (test.c:122)
==27702==    by 0x40157A: main (test.c:24)
==27702==
==27702== 40 bytes in 1 blocks are still reachable in loss record 2 of 3
==27702==    at 0x4C2AB80: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==27702==    by 0x56B058F: ??? (in /lib/x86_64-linux-gnu/libglib-2.0.so.0.4002.0)
==27702==    by 0x56B0634: ??? (in /lib/x86_64-linux-gnu/libglib-2.0.so.0.4002.0)
==27702==    by 0x56B0978: g_mutex_lock (in /lib/x86_64-linux-gnu/libglib-2.0.so.0.4002.0)
==27702==    by 0x5640D71: ??? (in /lib/x86_64-linux-gnu/libglib-2.0.so.0.4002.0)
==27702==    by 0x568A374: g_slice_alloc (in /lib/x86_64-linux-gnu/libglib-2.0.so.0.4002.0)
==27702==    by 0x565E17D: g_hash_table_new_full (in /lib/x86_64-linux-gnu/libglib-2.0.so.0.4002.0)
==27702==    by 0x4019E0: do_test_ini (test.c:122)
==27702==    by 0x40157A: main (test.c:24)
==27702==
==27702== 2,032 bytes in 1 blocks are still reachable in loss record 3 of 3
==27702==    at 0x4C2CC70: calloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==27702==    by 0x5674668: g_malloc0 (in /lib/x86_64-linux-gnu/libglib-2.0.so.0.4002.0)
==27702==    by 0x5641015: ??? (in /lib/x86_64-linux-gnu/libglib-2.0.so.0.4002.0)
==27702==    by 0x568A374: g_slice_alloc (in /lib/x86_64-linux-gnu/libglib-2.0.so.0.4002.0)
==27702==    by 0x565E17D: g_hash_table_new_full (in /lib/x86_64-linux-gnu/libglib-2.0.so.0.4002.0)
==27702==    by 0x4019E0: do_test_ini (test.c:122)
==27702==    by 0x40157A: main (test.c:24)
==27702==
==27702== LEAK SUMMARY:
==27702==    definitely lost: 0 bytes in 0 blocks
==27702==    indirectly lost: 0 bytes in 0 blocks
==27702==      possibly lost: 0 bytes in 0 blocks
==27702==    still reachable: 2,076 bytes in 3 blocks
==27702==         suppressed: 0 bytes in 0 blocks
==27702==
==27702== For counts of detected and suppressed errors, rerun with: -v
==27702== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 0 from 0)

求职 : 机器学习
论坛徽章:
79
2015年亚洲杯纪念徽章
日期:2015-05-06 19:18:572015七夕节徽章
日期:2015-08-21 11:06:172015亚冠之阿尔纳斯尔
日期:2015-09-07 09:30:232015亚冠之萨济拖拉机
日期:2015-10-21 08:26:3915-16赛季CBA联赛之浙江
日期:2015-12-30 09:59:1815-16赛季CBA联赛之浙江
日期:2016-01-10 12:35:21技术图书徽章
日期:2016-01-15 11:07:2015-16赛季CBA联赛之新疆
日期:2016-02-24 13:46:0215-16赛季CBA联赛之吉林
日期:2016-06-26 01:07:172015-2016NBA季后赛纪念章
日期:2016-06-28 17:44:45黑曼巴
日期:2016-06-28 17:44:4515-16赛季CBA联赛之浙江
日期:2017-07-18 13:41:54
2 [报告]
发表于 2014-12-19 08:47 |只看该作者
为啥提示找不到<glib.h>?

论坛徽章:
0
3 [报告]
发表于 2014-12-19 09:53 |只看该作者
zsszss0000 发表于 2014-12-19 08:47
为啥提示找不到?


直接 #include </usr/include/glib-2.0/glib.h>
或者 #include <glib-2.0/glib.h>

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
4 [报告]
发表于 2014-12-19 13:22 |只看该作者
glibc把malloc的内存不会归还给系统的,你可以直接malloc然后free同样会有这个问题。

论坛徽章:
17
处女座
日期:2013-08-27 09:59:352015亚冠之柏太阳神
日期:2015-07-30 10:16:402015亚冠之萨济拖拉机
日期:2015-07-29 18:58:182015年亚洲杯之巴勒斯坦
日期:2015-03-06 17:38:17摩羯座
日期:2014-12-11 21:31:34戌狗
日期:2014-07-20 20:57:32子鼠
日期:2014-05-15 16:25:21亥猪
日期:2014-02-11 17:32:05丑牛
日期:2014-01-20 15:45:51丑牛
日期:2013-10-22 11:12:56双子座
日期:2013-10-18 16:28:17白羊座
日期:2013-10-18 10:50:45
5 [报告]
发表于 2014-12-19 14:32 |只看该作者
回复 1# eglic_cu

试试这样运行:G_DEBUG=gc-friendly G_SLICE=always-malloc valgrind --db-attach=yes --tool=memcheck --leak-check=full --show-leak-kinds=all ./test.bin
因为glib有自己的内存管理策略,destory之类的函数并不表示把内存还给系统,也可以是还给glib的内存池,为了尽量消除glib自身内存策略的影响加上G_DEBUG=gc-friendly G_SLICE=always-malloc
   

论坛徽章:
0
6 [报告]
发表于 2014-12-19 21:54 |只看该作者
密林三木 发表于 2014-12-19 13:22
glibc把malloc的内存不会归还给系统的,你可以直接malloc然后free同样会有这个问题。


我用 g_malloc  和 g_free 没有问题的呀?

论坛徽章:
0
7 [报告]
发表于 2014-12-19 22:00 |只看该作者
myworkstation 发表于 2014-12-19 14:32
回复 1# eglic_cu

试试这样运行:G_DEBUG=gc-friendly G_SLICE=always-malloc valgrind --db-attach=ye ...


那这样的程序在服务器上长期用crond运行可靠吗(每小时运行一次)?
会不会导致服务器内存耗尽?
如果是的话,有没有什么办法可以不重启服务器来回收这些内存?

论坛徽章:
17
处女座
日期:2013-08-27 09:59:352015亚冠之柏太阳神
日期:2015-07-30 10:16:402015亚冠之萨济拖拉机
日期:2015-07-29 18:58:182015年亚洲杯之巴勒斯坦
日期:2015-03-06 17:38:17摩羯座
日期:2014-12-11 21:31:34戌狗
日期:2014-07-20 20:57:32子鼠
日期:2014-05-15 16:25:21亥猪
日期:2014-02-11 17:32:05丑牛
日期:2014-01-20 15:45:51丑牛
日期:2013-10-22 11:12:56双子座
日期:2013-10-18 16:28:17白羊座
日期:2013-10-18 10:50:45
8 [报告]
发表于 2014-12-20 10:27 |只看该作者
回复 7# eglic_cu


    进程退出时进程所占用的内存就被释放了,这是系统的行为。不用担心进程退出时有内存泄露。

论坛徽章:
0
9 [报告]
发表于 2014-12-21 10:04 |只看该作者
myworkstation 发表于 2014-12-20 10:27
回复 7# eglic_cu


好的,我在试试。

论坛徽章:
1
15-16赛季CBA联赛之辽宁
日期:2016-07-06 16:53:09
10 [报告]
发表于 2014-12-21 10:47 |只看该作者
hi.baidu.com/mcsekpfxhebikmq/item/b36fc5ee60ffcfd92a09a4bd
楼主可以看看这篇文章,手动试下就知道
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP