所以我在这里编写这段代码,我只想要一个函数来返回一个字符数组并将其分配给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工作并且分配失败?谁能告诉我我在这里做错了什么?
答案 0 :(得分:4)
您在函数中注释掉了null终止字符串的行。
main()
中只有一个案例中的段错误只是运气(未定义的行为);你也在你的函数中调用printf()
。