将字符串与用户输入分开而不是将其放入数组的分段错误

Posted

技术标签:

【中文标题】将字符串与用户输入分开而不是将其放入数组的分段错误【英文标题】:Segmentation Fault for separating a string from user input than putting it to a array 【发布时间】:2022-01-11 21:57:51 【问题描述】:

我试图从用户输入中获取一个带有空格的字符串,例如 "abcd12314 asdfg92743 ppoqws21321" 并将它们分开,然后将它们存储在一个数组中。但它给了我一个分段错误

int main() 
    char string[150];
    int i = 0;
    fgets(string, sizeof(string), stdin);
    char *words = strtok(string, " ");
    char *stored[150];

    while (words != NULL) 
        stored[i++] = words;
        words = strtok(NULL, " ");
    

    for (i = 0; i < strlen(string); i++) 
        printf("%s\n", stored[i]);
    

    return 0;

【问题讨论】:

你的for循环使用i &lt; strlen(string);,这是string中的字符数,而不是stored中的字符串数 【参考方案1】:

你想要这个:

int main() 
    char string[150];
    int i = 0;
    fgets(string,sizeof(string),stdin);
    char *words = strtok (string, " ");
    char *stored[150];

    while (words != NULL) 
        stored[i++] = words;
        words = strtok (NULL, " ");
    

    int nbofwords = i;                 // <<<< add this
    for (i = 0; i < nbofwords; i++)   // change this line
        printf("%s\n", stored[i]);
    
    return 0;

但是这段代码容易出错,你应该像下面这样写。您应该在第一次使用时声明变量并直接在for 语句中声明循环计数器。

int main() 
  char string[150];
  fgets(string, sizeof(string), stdin);

  char* stored[150];
  int nbofwords = 0;
  
  char* words = strtok(string, " ");
  while (words != NULL) 
    stored[nbofwords++] = words;
    words = strtok(NULL, " ");
  

  for (int i = 0; i < nbofwords; i++) 
    printf("%s\n", stored[i]);
  

  return 0;

免责声明:这是未经测试的代码。

【讨论】:

以上是关于将字符串与用户输入分开而不是将其放入数组的分段错误的主要内容,如果未能解决你的问题,请参考以下文章

获取用户输入,放入一个数组并打印出每个字母使用了多少次

为啥这个字符会出现分段错误?

在 C++ 中使用向量时出现分段错误?

将 IP:Port 字符串格式化为

C - 将结构写入二维数组会导致分段错误

分段错误而不是显示消息 - 使用 c 中的指针从文件中读取