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

导言

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()一样ÿ

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值