分配给char *时出现分段错误

时间:2011-10-22 04:44:26

标签: c char segmentation-fault

所以我在这里编写这段代码,我只想要一个函数来返回一个字符数组并将其分配给main函数中的变量。这是返回char *

的函数
char* getString(pid_t pid, long address, long length) 
{ 
    char* str =  (char *)malloc((length+1) * sizeof(char));
    int i =0;

    while (i < length)
    {
        char t = ptrace(PTRACE_PEEKDATA,pid,address+i,0); 
        str[i] = t; 
        i++;
    }
    //  str[length] = '\0';
    printf(" Exiting getString %s \n ", str);
    return str;
}

这就是我在主要做的事情

int main { 
    ... 
    ...  
    char* st = getString(pid, arguments[1], arguments[2]); // causes seg fault 
    // printf("getstring %s\n", getString(pid, arguments[1], arguments[2])); works fine
    // and produces correct output 
    return 1;
}

我最近在C中做的不多,所以也许我错过了什么,但是为什么printf工作并且分配失败?谁能告诉我我在这里做错了什么?

1 个答案:

答案 0 :(得分:4)

您在函数中注释掉了null终止字符串的行。

main()中只有一个案例中的段错误只是运气(未定义的行为);你也在你的函数中调用printf()