C String Return Function Returns Garbage

后端 未结 4 1106
夕颜
夕颜 2021-01-27 09:44

I\'m having trouble return a string from a function. It prints out a garbage value in the main method. I saw a similar question on this forum but the results on that page didn\'

相关标签:
4条回答
  • 2021-01-27 10:20

    Because of this line:

    result = path_name;
    

    This reassigns result to point to the local variable path_name, which goes out of scope when the function returns. This also means you have a memory leak.

    Instead of using the temporary path_name variable, write directly into result.

    0 讨论(0)
  • 2021-01-27 10:25

    You are assigning values path_name more than it can actually hold.

        strncat(path_name, dir[i], sizeof(path_name));
        strncat(path_name, "/", sizeof(path_name));
        strncat(path_name, argv[0], sizeof(path_name));
    

    should be:

        sprintf(path_name, "%s%s%s", dir[i],"/",argv[0]);
    
    0 讨论(0)
  • 2021-01-27 10:32

    You cannot return a local array (like your path_name) from a function. That local array is inside the call frame, which gets popped on return.

    As others replied, you should do

    strncpy(result, path_name, MAX_PATH_LEN);
    

    and document the convention that the caller should free the result.

    BTW, your code is quite inefficient; you are allocating a rather large chunk of MAX_PATH_LEN (often 4096) for a string which often is much smaller.

    If using GNU extensions you could simply use asprintf(3) (see this) or at least remove your malloc and return strdup(path_name); and use strdup(3) (which is standard, not requiring any GNU extension).

    And learn how to use valgrind.

    0 讨论(0)
  • 2021-01-27 10:34
    result = path_name;
    

    should be:

    strcpy(result, path_name);
    

    Or better, get rid of path_name and use result directly.

    Note that you should remember to free result when it's not used, when returning it, free it in the function that calls it. Since you return NULL in failure, in that case, free it directly, or it's a memory leak.

    And you are using strncat wrong, read the manual.

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