Glib程序使用Valgrind查找内存泄露
G_DEBUG=gc-friendly
G_SLICE=always-malloc //glib有缓存 故需使用
上述两条设置环境变量 G_SLICE和G_DEBUG排除由内存分配机制带来的影响
--tool=memcheck //使用valgrind的memcheck功能
-show-reachable=yes //是否检测控制范围之外的泄漏,比如全局指针、static指针等
--log-file=a.log //结果输出到文件
--leak-check=full //显示具体代码中泄漏的地方
--leak-resolution=high //
--num-callers=20
严格通用
G_SLICE=always-malloc G_DEBUG=gc-friendly valgrind --tool=memcheck --leak-check=full --leak-resolution=high --num-callers=20 --show-reachable=yes --log-file=a.log ./app
编写 valgrind_test.sh文件,内容如下
killall ../bin/test
export G_SLICE=always-malloc
export G_DEBUG=gc-friendly
valgrind --tool=memcheck --leak-check=full --leak-resolution=high ../bin/test --verbose --no-daemon --timed-exit &> ./valgrind_test.log
执行./valgrind_test.sh
查看结果文件valgrind_test.log,可以先查看LEAK SUMMARY:段,对于possibly lost可以不处理
==31312== Memcheck, a memory error detector
==31312== Copyright (C) 2002-2012, and GNU GPL'd, by Julian Seward et al.
==31312== Using Valgrind-3.8.1 and LibVEX; rerun with -h for copyright info
==31312== Command: ../bin/test --verbose --no-daemon --timed-exit
==31312==
** Message: called g_read_mr_init(mr_type:0)
** Message: called read_mr_file(mr_filename:../bin/input/mr_detail_201301141710.zcsv,mr_list_hash:0x7ff000050)
==31312== Warning: set address range perms: large range [0x59dc040, 0x259dc040) (undefined)
==31312== Conditional jump or move depends on uninitialised value(s)
==31312== at 0x4C28A1A: index (mc_replace_strmem.c:218)
==31312== by 0x404956: read_gsmmr_file (gsmmr.c:400)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== Conditional jump or move depends on uninitialised value(s)
==31312== at 0x4C28A2E: index (mc_replace_strmem.c:218)
==31312== by 0x404956: read_gsmmr_file (gsmmr.c:400)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312==
==31312== Conditional jump or move depends on uninitialised value(s)
==31312== at 0x40496F: read_gsmmr_file (gsmmr.c:424)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
** (process:31312): DEBUG: decompress 1954436 mr from ../bin/input/mr_detail_201301141710.zcsv
==31312== Warning: set address range perms: large range [0x59dc028, 0x259dc058) (noaccess)
g_hash_table_size (mr_list_hash)=36807 tv_sec=1358154474,tv_usec=214239000** Message: called g_read_mr_init(mr_type:0)
** Message: called read_mr_file(mr_filename:../bin/input/TD-SCDMA_MRO_HUAWEI_OSS_1600_20130527122900.bmr,mr_list_hash:0x7ff000050)
** (process:31312): DEBUG: decode 49796 mro_block from ../bin/input/TD-SCDMA_MRO_HUAWEI_OSS_1600_20130527122900.bmr
g_hash_table_size (mr_list_hash)=5040 tv_sec=1369628708,tv_usec=380000==31312==
==31312== HEAP SUMMARY:
==31312== in use at exit: 689,582,602 bytes in 576,558 blocks
==31312== total heap usage: 19,806,784 allocs, 19,230,226 frees, 2,099,437,182 bytes allocated
==31312==
==31312== 15 bytes in 1 blocks are possibly lost in loss record 1 of 53
==31312== at 0x4C278FE: malloc (vg_replace_malloc.c:270)
==31312== by 0x31A20417D2: g_malloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2058F7D: g_strdup (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2068FE0: g_get_charset (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2042C61: g_log_default_handler (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2042FF8: g_logv (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2043412: g_log (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404FEC: g_read_mr_init (mrread.c:37)
==31312== by 0x404BC3: test_read_gsmmr_file (test_mrread.h:22)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 15 bytes in 1 blocks are possibly lost in loss record 2 of 53
==31312== at 0x4C278FE: malloc (vg_replace_malloc.c:270)
==31312== by 0x31A20417D2: g_malloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2058F7D: g_strdup (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20690B0: g_get_charset (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2042C61: g_log_default_handler (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2042FF8: g_logv (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2043412: g_log (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404FEC: g_read_mr_init (mrread.c:37)
==31312== by 0x404BC3: test_read_gsmmr_file (test_mrread.h:22)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 16 bytes in 1 blocks are possibly lost in loss record 3 of 53
==31312== at 0x4C278FE: malloc (vg_replace_malloc.c:270)
==31312== by 0x4C27A72: realloc (vg_replace_malloc.c:662)
==31312== by 0x31A2041620: g_realloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20142DA: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A201439A: g_array_set_size (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20622A7: g_static_private_set (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20690F2: g_get_charset (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2042C61: g_log_default_handler (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2042FF8: g_logv (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2043412: g_log (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404FEC: g_read_mr_init (mrread.c:37)
==31312== by 0x404BC3: test_read_gsmmr_file (test_mrread.h:22)
==31312==
==31312== 24 bytes in 1 blocks are possibly lost in loss record 4 of 53
==31312== at 0x4C2668B: calloc (vg_replace_malloc.c:593)
==31312== by 0x31A2041707: g_malloc0 (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20690D9: g_get_charset (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2042C61: g_log_default_handler (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2042FF8: g_logv (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2043412: g_log (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404FEC: g_read_mr_init (mrread.c:37)
==31312== by 0x404BC3: test_read_gsmmr_file (test_mrread.h:22)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 240 bytes in 1 blocks are possibly lost in loss record 6 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2057D7D: g_slist_prepend (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404ED3: main (main.c:26)
==31312==
==31312== 496 bytes in 1 blocks are possibly lost in loss record 8 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A205C36A: g_string_sized_new (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2042A4E: g_log_default_handler (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2042FF8: g_logv (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2043412: g_log (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404FEC: g_read_mr_init (mrread.c:37)
==31312== by 0x404BC3: test_read_gsmmr_file (test_mrread.h:22)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 1,008 bytes in 1 blocks are possibly lost in loss record 12 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A202B1D2: g_hash_table_new_full (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404654: read_gsmmr_file (gsmmr.c:350)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 1,008 bytes in 1 blocks are possibly lost in loss record 13 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A202B1D2: g_hash_table_new_full (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404654: read_gsmmr_file (gsmmr.c:350)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 1,488 bytes in 3 blocks are possibly lost in loss record 14 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A205C36A: g_string_sized_new (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2042A4E: g_log_default_handler (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2042FF8: g_logv (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2043412: g_log (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404FEC: g_read_mr_init (mrread.c:37)
==31312== by 0x404BC3: test_read_gsmmr_file (test_mrread.h:22)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 3,472 bytes in 7 blocks are possibly lost in loss record 17 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2036D5D: g_list_prepend (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A202ABB9: g_hash_table_get_values (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404C7D: test_read_gsmmr_file (test_mrread.h:30)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 49,920 bytes in 208 blocks are possibly lost in loss record 19 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20568E5: g_slice_alloc0 (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x403F0F: mr_new (gsmmr.c:162)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 51,120 bytes in 213 blocks are possibly lost in loss record 20 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20568E5: g_slice_alloc0 (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x403E12: mr_new (gsmmr.c:136)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 56,160 bytes in 234 blocks are possibly lost in loss record 21 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2057D7D: g_slist_prepend (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x403E7A: mr_new (gsmmr.c:143)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 101,040 bytes in 421 blocks are possibly lost in loss record 22 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20568E5: g_slice_alloc0 (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x40421B: mr_new (gsmmr.c:241)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 101,520 bytes in 423 blocks are possibly lost in loss record 23 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2057D7D: g_slist_prepend (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x40407E: mr_new (gsmmr.c:195)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 106,560 bytes in 444 blocks are possibly lost in loss record 24 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2057D7D: g_slist_prepend (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404182: mr_new (gsmmr.c:221)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 109,440 bytes in 456 blocks are possibly lost in loss record 25 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2057D7D: g_slist_prepend (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x403F7A: mr_new (gsmmr.c:169)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 109,680 bytes in 457 blocks are possibly lost in loss record 26 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2057D7D: g_slist_prepend (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x40438A: mr_new (gsmmr.c:274)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 111,120 bytes in 463 blocks are possibly lost in loss record 27 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2057D7D: g_slist_prepend (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404286: mr_new (gsmmr.c:248)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 111,120 bytes in 463 blocks are possibly lost in loss record 28 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2057D7D: g_slist_prepend (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x40448E: mr_new (gsmmr.c:300)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 112,320 bytes in 468 blocks are possibly lost in loss record 29 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20568E5: g_slice_alloc0 (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404117: mr_new (gsmmr.c:214)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 115,200 bytes in 480 blocks are possibly lost in loss record 30 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20568E5: g_slice_alloc0 (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404013: mr_new (gsmmr.c:188)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 115,440 bytes in 481 blocks are possibly lost in loss record 31 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20568E5: g_slice_alloc0 (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404423: mr_new (gsmmr.c:293)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 117,360 bytes in 489 blocks are possibly lost in loss record 32 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20568E5: g_slice_alloc0 (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x40431F: mr_new (gsmmr.c:267)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 126,960 bytes in 529 blocks are possibly lost in loss record 33 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2057D7D: g_slist_prepend (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404914: read_gsmmr_file (gsmmr.c:418)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 173,600 bytes in 350 blocks are possibly lost in loss record 34 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2036D5D: g_list_prepend (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A202ABB9: g_hash_table_get_values (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404C7D: test_read_gsmmr_file (test_mrread.h:30)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 4,856,400 bytes in 20,235 blocks are possibly lost in loss record 35 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2057D7D: g_slist_prepend (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x40438A: mr_new (gsmmr.c:274)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 4,926,240 bytes in 20,526 blocks are possibly lost in loss record 36 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2057D7D: g_slist_prepend (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404914: read_gsmmr_file (gsmmr.c:418)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 4,946,640 bytes in 20,611 blocks are possibly lost in loss record 37 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2057D7D: g_slist_prepend (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x40407E: mr_new (gsmmr.c:195)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 4,957,920 bytes in 20,658 blocks are possibly lost in loss record 38 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20568E5: g_slice_alloc0 (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404423: mr_new (gsmmr.c:293)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 4,971,360 bytes in 20,714 blocks are possibly lost in loss record 39 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20568E5: g_slice_alloc0 (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x40431F: mr_new (gsmmr.c:267)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 4,983,120 bytes in 20,763 blocks are possibly lost in loss record 40 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2057D7D: g_slist_prepend (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x40448E: mr_new (gsmmr.c:300)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 5,015,280 bytes in 20,897 blocks are possibly lost in loss record 41 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20568E5: g_slice_alloc0 (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x403E12: mr_new (gsmmr.c:136)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 5,017,920 bytes in 20,908 blocks are possibly lost in loss record 42 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2057D7D: g_slist_prepend (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x403E7A: mr_new (gsmmr.c:143)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 5,031,360 bytes in 20,964 blocks are possibly lost in loss record 43 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20568E5: g_slice_alloc0 (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x403F0F: mr_new (gsmmr.c:162)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 5,034,960 bytes in 20,979 blocks are possibly lost in loss record 44 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20568E5: g_slice_alloc0 (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x40421B: mr_new (gsmmr.c:241)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 5,036,640 bytes in 20,986 blocks are possibly lost in loss record 45 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2057D7D: g_slist_prepend (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404182: mr_new (gsmmr.c:221)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 5,122,080 bytes in 21,342 blocks are possibly lost in loss record 46 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2057D7D: g_slist_prepend (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x403F7A: mr_new (gsmmr.c:169)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 5,136,000 bytes in 21,400 blocks are possibly lost in loss record 47 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20568E5: g_slice_alloc0 (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404013: mr_new (gsmmr.c:188)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 5,156,160 bytes in 21,484 blocks are possibly lost in loss record 48 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20568E5: g_slice_alloc0 (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404117: mr_new (gsmmr.c:214)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 5,175,360 bytes in 21,564 blocks are possibly lost in loss record 49 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2057D7D: g_slist_prepend (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x404286: mr_new (gsmmr.c:248)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 14,407,344 bytes in 14,293 blocks are possibly lost in loss record 50 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20568E5: g_slice_alloc0 (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x403B51: mr_new (gsmmr.c:60)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 86,786,784 bytes in 86,098 blocks are possibly lost in loss record 51 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20568E5: g_slice_alloc0 (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x403B51: mr_new (gsmmr.c:60)
==31312== by 0x4048DC: read_gsmmr_file (gsmmr.c:414)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 149,042,432 bytes in 42,288 blocks are possibly lost in loss record 52 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A20567CB: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x40488D: read_gsmmr_file (gsmmr.c:403)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== 362,291,808 bytes in 113,242 blocks are possibly lost in loss record 53 of 53
==31312== at 0x4C26458: memalign (vg_replace_malloc.c:727)
==31312== by 0x4C264F3: posix_memalign (vg_replace_malloc.c:876)
==31312== by 0x31A2055F47: ??? (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x31A2056801: g_slice_alloc (in /lib64/libglib-2.0.so.0.2200.5)
==31312== by 0x40488D: read_gsmmr_file (gsmmr.c:403)
==31312== by 0x40507B: read_mr_file (mrread.c:56)
==31312== by 0x404BEE: test_read_gsmmr_file (test_mrread.h:26)
==31312== by 0x404EE3: main (main.c:28)
==31312==
==31312== LEAK SUMMARY:
==31312== definitely lost: 0 bytes in 0 blocks
==31312== indirectly lost: 0 bytes in 0 blocks
==31312== possibly lost: 689,572,150 bytes in 576,549 blocks
==31312== still reachable: 10,452 bytes in 9 blocks
==31312== suppressed: 0 bytes in 0 blocks
==31312== Reachable blocks (those to which a pointer was found) are not shown.
==31312== To see them, rerun with: --leak-check=full --show-reachable=yes
==31312==
==31312== For counts of detected and suppressed errors, rerun with: -v
==31312== Use --track-origins=yes to see where uninitialised values come from
==31312== ERROR SUMMARY: 48 errors from 48 contexts (suppressed: 4 from 4)
Glib程序使用Valgrind查找内存泄露的更多相关文章
- Valgrind查找内存泄露利器
Valgrind是一个GPL的软件,用于Linux(For x86, amd64 and ppc32)程序的内存调试和代码剖析.你可以在它的环境中运行你的程序来监视内存的使用情况,比如C 语言中的ma ...
- Android中如何查找内存泄露
1.首先确定是否有内存泄露及哪个程序造成. 1.1.内存泄露已弹出out of memory对话框的情况. 这种情况很简单,直接看对话框就知道是哪个应用的问题了.然后再分析该应用是否是因为内存泄露造成 ...
- 使用UMDH查找内存泄露
参考文献: 1.http://blog.csdn.net/wcjy07220114/article/details/6962140 2.http://blog.csdn.net/chenyujing1 ...
- 用poolmon来查找内存泄露
用poolmon来查找内存泄露 poolmon C:\WinDDK\7600.16385.1\tools\Other\i386\poolmon.exegflags C:\WinDDK\7600 ...
- Valgrind检测内存泄露简介
原文地址: Valgrind 概述 体系结构 Valgrind是一套Linux下,开放源代码(GPL V2)的仿真调试工具的集合.Valgrind由内核(core)以及基于内核的其他调试工具组成.内核 ...
- leaks工具查找内存泄露
作为一名iOS开发攻城狮,在苹果没有出ARC(自动内存管理机制)时,我们几乎有一半的开发时间都耗费在这么管理内存上.后来苹果很人性的出了ARC,虽然在很大程度上,帮助我们开发者节省了精力和时间.但是我 ...
- Linux 下用 valgrind 查找内存泄漏小例子
1.安装 valgrind yum install valgrind 2.测试用例 main.cpp #include <iostream> using namespace std; st ...
- valgrind 检查内存泄露
https://www.oschina.net/translate/valgrind-memcheck
- 用Eclipse Memory Analyzer查找内存泄露
写在CSDN里面了 http://blog.csdn.net/dayulxl/article/details/78164301
随机推荐
- 阿里大鱼短信接口整合Tp3.2.3开发整理
阿里大鱼 http://www.alidayu.com/ 的短信接口总体是不错的,别安驹个人认为不管是从性价比还是稳定性上都是跟同类的短信接口好些,毕竟是大公司的东西不会差到哪去.下面把之前开发的短信 ...
- codeforces 几道题目
BZOJ挂了....明天就要出发去GDKOI了....不能弃疗. 于是在cf水了几道题, 写写详(jian)细(dan)题解, 攒攒RP, 希望GDKOI能好好发挥....... 620E. New ...
- 【原】YUI3:js加载过程及时序问题
时序问题在javascript中比较常见,尤其是在网络环境不稳定时以及某些浏览器本来版本中比较多,遇到此类问题,往往会使开发者非常头痛,问题的重现需要特定的环境,是偶发的,不容易重现.对于有经验的开发 ...
- scroll运用、图片悬浮
scroll 滚动条 长话短说进入正题: scrollTOP==0 内容置于顶部: scrollTOP()>=$(document).height-$(window).height 内容置于底部 ...
- Node.js包管理器:
Node.js包管理器: 当我们要把某个包作为工程运行的一部分时,通过本地模式获取,如果要在命令行下使用,则使用全局模式安装 使用全局模式安装的包并不能直接在JavaScript文件中用require ...
- [ReactiveCocoa]最简单的RAC入门操作
当knowckout.js出来的时候,确实被其kobinding惊艳了一下,等到AngularJS出来的时候,把MVVM的模式更是向前推进了一步.所以当ReactiveCocoa出来的时候,也很感兴趣 ...
- DenyHosts 安装及配置详解
DenyHosts是Python语言写的一个程序,它会分析sshd的日志文件(/var/log/secure),当发现重 复的攻击时就会记录IP到/etc/hosts.deny文件,从而达到自动屏IP ...
- Qt中添加OpenCV库
配置在Qt中的OpenCV,看了很多“教程”,最终成功.记一下过程. 本机配置: window7 32位系统: qt-opensource-windows-x86-mingw492-5.5.1: Op ...
- cat监控平台环境搭建
项目地址:https://github.com/dianping/cat 编译步骤: 这个项目比较另类,把编译需要的jar包,单独放在git分支mvn-repo里了,而且官方文档里给了一个错误的命令提 ...
- UI线程与worker线程
也谈谈我对UI线程和worker线程的理解 UI线程又叫界面线程,能够响应操作系统的特定消息,包括界面消息.鼠标键盘消息.自定义消息等,是在普通的worker线程基础上加上消息循环来实现的,在这个消息 ...