我编写了一个简单的函数,用于在Linux中为函数C
生成一个execvp
字符串(NOT C ++)。
这是我的代码:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
char** vecting(char *cstring) {
int w_count = 0; //word count
char *flag = cstring;
while (*flag != '\0') {
if (*flag == ' ' || *flag == '\n' || *flag == '\t')
*flag = '\0';
flag++;
else {
w_count++;
while (*flag != ' ' && *flag != '\n' && *flag != '\t' && *flag != '\0')
flag++;
}
}
char **cvector = (char **)malloc(sizeof(char *)*(w_count+1));
cvector[w_count] = NULL;
int v_count; //vector count
for (v_count = 0, flag = cstring; v_count < w_count; v_count++) {
while (*flag == '\0')
flag++;
cvector[v_count] = flag;
while (*flag != '\0')
flag++;
}
return cvector;
}
int main()
{
char *p = "This is a BUG";
char **argv = vecting(p);
char **temp;
for (temp = argv; *temp != NULL; temp++)
printf("%s\n", *temp);
return 0;
}
当我运行它时,我得它Segmentation fault
。
然后我调试它,我刚刚发现,运行时
*flag = '\0'; //(in line 12)
编程接收信号SIGSEGV,分段故障。
当时*flag = ' '
我无法理解程序在程序更改cstring
答案 0 :(得分:6)
char *p = "This is a BUG";
是一个字符串文字,它是未定义的行为来修改它。 char *flag = cstring;
表示flag
指向同一位置(恰好是只读内存)为p
。你试图做的事情(现在是这样)是非法的。
尝试
char p[] = "This is a BUG";
答案 1 :(得分:1)
获取SIGSEGV的原因是"This is the bug"
字符串被放入const部分。加载程序时,相应的存储区标记为只读。当程序尝试写入只读存储区时,它会收到分段错误。