gets(c基础)

  1. gets函数的定义
    • gets函数用于从标准输入(通常是键盘)读取一行字符串。它的函数原型如下:

  • 其中,参数s是一个字符指针,指向用于存储输入字符串的字符数组。

  1. gets函数的使用方法
    • 当调用gets函数时,它会一直读取字符,直到遇到换行符\n为止。然后它会将换行符替换为字符串结束标志\0,并返回指向输入字符串的指针(也就是参数s)。
    • 例如:
#include <stdio.h>

int main() {
    char str[100];
    printf("Enter a string: ");
    gets(str);
    printf("You entered: %s\n", str);
    return 0;
}

  • 在这个例子中,用户输入的字符串会被gets函数读取并存储在str数组中,然后再被打印出来。

  1. gets函数的安全问题
    • gets函数存在严重的安全隐患,它不会检查输入字符串的长度,这可能导致缓冲区溢出。
    • 例如,如果定义了一个长度为 10 的字符数组,而用户输入了超过 10 个字符的字符串,gets函数会继续向内存中写入数据,可能会覆盖其他重要的数据,导致程序崩溃甚至被恶意利用(如栈溢出攻击)。
    • 由于这个安全问题,gets函数在新的 C 标准(如 C11)中已经被弃用。取而代之的是更安全的函数,如fgets
  2. fgetsgets的对比
    • fgets函数的原型如下:
char *fgets(char *s, int size, FILE *stream);

  • 其中,s是存储输入字符串的字符数组,size是要读取的最大字符数(包括字符串结束标志\0),stream是输入流(通常为stdin表示标准输入)。
  • fgets会读取最多size - 1个字符(为\0留出空间),或者读到换行符\n为止。这样就避免了缓冲区溢出的问题。例如:

#include <stdio.h>

int main() {
    char str[10];
    printf("Enter a string: ");
    fgets(str, sizeof(str), stdin);
    printf("You entered: %s", str);
    return 0;
}

  • 在这个例子中,fgets最多会读取10 - 1 = 9个字符,防止了缓冲区溢出。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值