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查找内存泄露的更多相关文章

  1. Valgrind查找内存泄露利器

    Valgrind是一个GPL的软件,用于Linux(For x86, amd64 and ppc32)程序的内存调试和代码剖析.你可以在它的环境中运行你的程序来监视内存的使用情况,比如C 语言中的ma ...

  2. Android中如何查找内存泄露

    1.首先确定是否有内存泄露及哪个程序造成. 1.1.内存泄露已弹出out of memory对话框的情况. 这种情况很简单,直接看对话框就知道是哪个应用的问题了.然后再分析该应用是否是因为内存泄露造成 ...

  3. 使用UMDH查找内存泄露

    参考文献: 1.http://blog.csdn.net/wcjy07220114/article/details/6962140 2.http://blog.csdn.net/chenyujing1 ...

  4. 用poolmon来查找内存泄露

    用poolmon来查找内存泄露 poolmon C:\WinDDK\7600.16385.1\tools\Other\i386\poolmon.exegflags     C:\WinDDK\7600 ...

  5. Valgrind检测内存泄露简介

    原文地址: Valgrind 概述 体系结构 Valgrind是一套Linux下,开放源代码(GPL V2)的仿真调试工具的集合.Valgrind由内核(core)以及基于内核的其他调试工具组成.内核 ...

  6. leaks工具查找内存泄露

    作为一名iOS开发攻城狮,在苹果没有出ARC(自动内存管理机制)时,我们几乎有一半的开发时间都耗费在这么管理内存上.后来苹果很人性的出了ARC,虽然在很大程度上,帮助我们开发者节省了精力和时间.但是我 ...

  7. Linux 下用 valgrind 查找内存泄漏小例子

    1.安装 valgrind yum install valgrind 2.测试用例 main.cpp #include <iostream> using namespace std; st ...

  8. valgrind 检查内存泄露

    https://www.oschina.net/translate/valgrind-memcheck

  9. 用Eclipse Memory Analyzer查找内存泄露

    写在CSDN里面了 http://blog.csdn.net/dayulxl/article/details/78164301

随机推荐

  1. C# 获取本机IP地址以及转换字符串

    /// <summary> /// IP地址转化 /// </summary> /// <param name="ipaddr">整型的IP地址 ...

  2. Three.js学习笔记 – “我和小伙伴都惊呆了”的特效和Three.js初探

    什么是Three.js three.js是JavaScript编写的WebGL第三方库.提供了非常多的3D显示功能.Three.js 是一款运行在浏览器中的 3D 引擎,你可以用它创建各种三维场景,包 ...

  3. ZRender源码分析3:Painter(View层)-上

    回顾 上一篇说到:ZRender源码分析2:Storage(Model层),这次咱看来看看Painter-View层 总体理解 Painter这个类主要负责MVC中的V(View)层,负责将Stora ...

  4. mysqli扩展库的 预处理技术 mysqli stmt

    问题的提出? 现在需要向mysql数据库添加100个用户,请问如何实现? 思路: 使用for循环100次,向数据库中添加100个用户. 使用批量添加 $sql1=”insert xxx”; $ssql ...

  5. 《UNIX网络编程》TCP客户端服务器:并发、消息回显

    经过小小改动,把前面基础的例子做出一点修改. 并发服务器,服务器每accept一个请求就fork()一个新的子进程. 编译运行方法同前一篇. /*client_tcp.c*/ #include < ...

  6. iOS中通知传值

    NSNotification 通知中心传值,可以跨越多个页面传值, 一般也是从后面的页面传给前面的页面.   思路: 第三个界面的值传给第一个界面. 1. 在第一个界面建立一个通知中心, 通过通知中心 ...

  7. react-native component function

    examples: use:

  8. 在magento中发邮件

    1. 在system->Configuration->Store Email Addresses中设置General Contact的Sender Name.Sender Email. S ...

  9. MAC xampp 启动失败

    原文地址: http://meiyitianabc.blog.163.com/blog/static/1050221272013116232752/ 问题:80port被暂用,导致server无法启动 ...

  10. C#的输入输出及基本类型

    //输出 Console.WriteLine("摩西摩西"); Console.Write("hollo");不带回车的 注意: 1.注意大小写敏感.(快捷键操 ...