亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 3989 | 回復: 9
打印 上一主題 下一主題

[C] 求助:glib 2.40.2 疑似內存泄漏問題 [復制鏈接]

論壇徽章:
0
跳轉到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2014-12-18 16:55 |只看該作者 |倒序瀏覽
初次使用Glib,代碼基本寫完之后,順手測試下,發(fā)現(xiàn)
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七夕節(jié)徽章
日期:2015-08-21 11:06:172015亞冠之阿爾納斯爾
日期:2015-09-07 09:30:232015亞冠之薩濟拖拉機
日期:2015-10-21 08:26:3915-16賽季CBA聯(lián)賽之浙江
日期:2015-12-30 09:59:1815-16賽季CBA聯(lián)賽之浙江
日期:2016-01-10 12:35:21技術圖書徽章
日期:2016-01-15 11:07:2015-16賽季CBA聯(lián)賽之新疆
日期:2016-02-24 13:46:0215-16賽季CBA聯(lián)賽之吉林
日期:2016-06-26 01:07:172015-2016NBA季后賽紀念章
日期:2016-06-28 17:44:45黑曼巴
日期:2016-06-28 17:44:4515-16賽季CBA聯(lián)賽之浙江
日期:2017-07-18 13:41:54
2 [報告]
發(fā)表于 2014-12-19 08:47 |只看該作者
為啥提示找不到<glib.h>?

論壇徽章:
0
3 [報告]
發(fā)表于 2014-12-19 09:53 |只看該作者
zsszss0000 發(fā)表于 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 [報告]
發(fā)表于 2014-12-19 13:22 |只看該作者
glibc把malloc的內存不會歸還給系統(tǒng)的,你可以直接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 [報告]
發(fā)表于 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之類的函數(shù)并不表示把內存還給系統(tǒng),也可以是還給glib的內存池,為了盡量消除glib自身內存策略的影響加上G_DEBUG=gc-friendly G_SLICE=always-malloc
   

論壇徽章:
0
6 [報告]
發(fā)表于 2014-12-19 21:54 |只看該作者
密林三木 發(fā)表于 2014-12-19 13:22
glibc把malloc的內存不會歸還給系統(tǒng)的,你可以直接malloc然后free同樣會有這個問題。


我用 g_malloc  和 g_free 沒有問題的呀?

論壇徽章:
0
7 [報告]
發(fā)表于 2014-12-19 22:00 |只看該作者
myworkstation 發(fā)表于 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 [報告]
發(fā)表于 2014-12-20 10:27 |只看該作者
回復 7# eglic_cu


    進程退出時進程所占用的內存就被釋放了,這是系統(tǒng)的行為。不用擔心進程退出時有內存泄露。

論壇徽章:
0
9 [報告]
發(fā)表于 2014-12-21 10:04 |只看該作者
myworkstation 發(fā)表于 2014-12-20 10:27
回復 7# eglic_cu


好的,我在試試。

論壇徽章:
1
15-16賽季CBA聯(lián)賽之遼寧
日期:2016-07-06 16:53:09
10 [報告]
發(fā)表于 2014-12-21 10:47 |只看該作者
hi.baidu.com/mcsekpfxhebikmq/item/b36fc5ee60ffcfd92a09a4bd
樓主可以看看這篇文章,手動試下就知道
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復

  

北京盛拓優(yōu)訊信息技術有限公司. 版權所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關心和支持過ChinaUnix的朋友們 轉載本站內容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP