C中的危险函数(缓冲区溢出)

C语言因其直接内存访问特性而具有危险的函数,如gets()和strcpy/strcat,它们可能导致缓冲区溢出。文章提醒开发者永远不要使用gets(),建议使用fgets()替代,并推荐使用strncpy()和strncat()来避免潜在的安全问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

导言

C语言,自创始以来,到现在经久不衰。虽然C你只好自己造轮子,由于C语言允许直接访问物理地址,可以直接对硬件进行操作,因此它既具有高级语言的功能,又具有低级语言的特性。所以有可移植的汇编之称。
可是也在这些直接对内存的访问,导致了危险的发生。

有了自由也就多了混乱 ————某斯基

那些危险的函数们

gets()

第一位公共敌人就是是 gets(),永远不要使用 gets()。该函数从标准输入读入用户输入的一行文本,它在遇到 EOF 字符或换行字符之前,不会停止读入文本。也就是:gets() 根本不执行边界检查。因此,使用 gets() 总是有可能使任何缓冲区溢出。
如以下代码:

    char *p = (char *) malloc(8);
    gets(p);
    printf("%s",p);
    free(p);
    return 0;

效果如下
这里写图片描述
可见,gets()这个函数可以在不经意间溢出任何的缓冲区0.0
所以,还是老话:永远不要使用 gets()!
那么怎么办呢?可以用fget()来代替啊~
参数如下

fgets(buf, BUFSIZE, stdin);

这个用处和gets()一样,只是额外加入了限制接收长度的参数;

strcpy&strcat

strcpy()函数将源字符串复制到缓冲区。没有指定要复制字符的具体数目。复制字符的数目直接取决于源字符串中的数目。如果源字符串碰

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值