Sizeof vs Strlen

前端 未结 4 816
北荒
北荒 2020-11-29 02:49
#include 
#include 

int main(int argc, char *argv[]) {
    char string[] = \"october\"; // 7 le         


        
相关标签:
4条回答
  • 2020-11-29 03:12

    You must eliminate buffer overflow problem in this example. One way to do this - is to use strncpy:

    memset(string, 0, sizeof(string));
    strncpy(string, "september", sizeof(string)-1);
    
    0 讨论(0)
  • 2020-11-29 03:18

    sizeof and strlen() do different things. In this case, your declaration

    char string[] = "october";
    

    is the same as

    char string[8] = "october";
    

    so the compiler can tell that the size of string is 8. It does this at compilation time.

    However, strlen() counts the number of characters in the string at run time. So, after you call strcpy(), string now contains "september". strlen() counts the characters and finds 9 of them. Note that you have not allocated enough space for string to hold "september". This is undefined behaviour.

    0 讨论(0)
  • 2020-11-29 03:26

    Your destination array is 8 bytes (length of "october" plus \0) and you want to put in 9 chars in that array.

    man strcpy says: If the destination string of a strcpy() is not large enough, then anything might happen.

    Please tell me what you really want to do, because this smells bad long way

    0 讨论(0)
  • 2020-11-29 03:39

    The Output is correct because

    first statement string size was allocated by compiler that is 7+1 (October is 7 bytes & 1 byte for null terminator at compile time)

    Second statement: you are copying September (9 bytes to 8 bytes string);

    there for you got size of September as 8 bytes (still strlen() will not work for September it does not have null character)

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