The valgrind reports error when printing allocated strings

后端 未结 2 574
半阙折子戏
半阙折子戏 2021-01-12 21:36

The code is here:

#include 
#include 
#include 

int main()
{
    char* buf = malloc(3);
    strcpy(buf, \"hi\         


        
相关标签:
2条回答
  • 2021-01-12 21:53

    I've run it in my own machine, and I get no errors:

    ==61755== Memcheck, a memory error detector
    ==61755== Copyright (C) 2002-2009, and GNU GPL'd, by Julian Seward et al.
    ==61755== Using Valgrind-3.5.0 and LibVEX; rerun with -h for copyright info
    ==61755== Command: ./a.out
    ==61755==
    hi
    ==61755==
    ==61755== HEAP SUMMARY:
    ==61755==     in use at exit: 0 bytes in 0 blocks
    ==61755==   total heap usage: 1 allocs, 1 frees, 3 bytes allocated
    ==61755==
    ==61755== All heap blocks were freed -- no leaks are possible
    ==61755==
    ==61755== For counts of detected and suppressed errors, rerun with: -v
    ==61755== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 6 from 6)
    
    0 讨论(0)
  • 2021-01-12 22:16

    This is a bug, but not reproducible on all machines.

    On some machines, gcc optimizes simple printf() with, for example, puts(), which could possibly involve invalid read (or just valgrind thinks so).

    If it really matters, you can 'complicate' the printf format. A space between %s and \n would do.

    Here is a similar bug: C strings, strlen and Valgrind

    This answer combines comments in the discussion. Thank you all!

    0 讨论(0)
提交回复
热议问题