==20420==
==20420== HEAP SUMMARY:
==20420== in use at exit: 0 bytes in 1 blocks
==20420== total heap usage: 1 allocs, 0 frees, 0 bytes allocated
==20420==
==20420== Searching for pointers to 1 not-freed blocks
==20420== Checked 48,492 bytes
==20420==
==20420== 0 bytes in 1 blocks are still reachable in loss record 1 of 1
==20420== at 0x400677E: malloc (vg_replace_malloc.c:195)
==20420== by 0x80483D8: main (jig.c:10)
==20420==
==20420== LEAK SUMMARY:
==20420== definitely lost: 0 bytes in 0 blocks
==20420== indirectly lost: 0 bytes in 0 blocks
==20420== possibly lost: 0 bytes in 0 blocks
==20420== still reachable: 0 bytes in 1 blocks
==20420== suppressed: 0 bytes in 0 blocks
Смотрите в своем проекте, я использую malloc следующим образом:
malloc(sizeof(some_structure) * some_expression);
в какой-то момент some_expression дает значение 0, так что косвенно я делаю
malloc(0)
Так что, когда яЯ не собираюсь выделять один байт, поэтому я не освобождаю его, но в этом случае valgrind обнаруживает утечку памяти.Почему?
Редактировать:
Если я использую вот так:
char *a = malloc(0);
Тогда a не NULL.Так что вопрос, почему не NULL?& Какой адрес он хранит?