八义士 发表于 2024-9-14 17:57:04

程序异常中断

#include <stdio.h>
int main(){
    char str1 = {0};
    char str2 = {0};
    char str3 = {0};

    //gets() 用法
    printf("Input a string: ");
    gets(str1);

    //scanf() 用法
    printf("Input a string: ");
    scanf_s("%s", str2);
   scanf_s("%s", str3);
   
    printf("\nstr1: %s\n", str1);
    printf("str2: %s\n", str2);
    printf("str3: %s\n", str3);
        while(1);
    return 0;
}

FishC 发表于 2024-9-14 18:02:20

你好,根据你的代码,程序会在`gets()`函数调用时出现异常中断。这个问题主要涉及到几个方面:

1. **字符串数组初始化问题**:
   你将字符串定义为`char`类型数组,并在初始化时长度为1(`{0}`),所以只能存储一个字符。另外,初始化方式有问题。
   
2. **使用`gets()`函数的问题**:
   `gets()`是比较危险的函数,它不对输入的长度进行检查,可能会导致缓冲区溢出。这也是在C11标准中被废弃的原因。建议使用`fgets()`代替。

3. **使用`scanf_s()`的方式不正确**:
   `scanf_s()`是微软引入的安全版本,需要额外的参数来指定缓冲区的大小。你需要在每次读取字符串时指明缓冲区长度。

可以按照以下修改方式重新编写代码:

#include <stdio.h>

int main() {
    char str1 = {0};// 增大数组大小
    char str2 = {0};
    char str3 = {0};
   
    // 使用 fgets 代替 gets
    printf("Input a string: ");
    fgets(str1, sizeof(str1), stdin);
   
    //使用 scanf_s,正确方式
    printf("Input a string: ");
    scanf_s("%99s", str2, (unsigned)_countof(str2));

    printf("Input another string: ");
    scanf_s("%99s", str3, (unsigned)_countof(str3));
   
    printf("\nstr1: %s\n", str1);
    printf("str2: %s\n", str2);
    printf("str3: %s\n", str3);

    while(1);
    return 0;
}

关键修改点:

1. 增大了字符数组的大小,防止溢出。
2. 使用`fgets()`代替`gets()`,可以防止缓冲区溢出。
3. `scanf_s()`的使用需要额外参数来指定缓冲区长度。

以上修改将会避免程序异常中断问题,更加安全稳定。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。

jackz007 发表于 2024-9-14 18:31:46

scanf_s("%s", str2);
scanf_s("%s", str3);
      改为:
scanf_s("%s" , str2 , 30);
scanf_s("%s" , str3 , 30);

人造人 发表于 2024-9-14 18:35:33

scanf_s("%s", str2);
scanf_s("%s", str3);
      改为:
scanf("%s", str2);
scanf("%s", str3);

sfqxx 发表于 2024-9-15 08:38:42

把 scanf_s 改成 scanf
页: [1]
查看完整版本: 程序异常中断