发现问题
成都创新互联专注为客户提供全方位的互联网综合服务,包含不限于成都做网站、网站制作、成都外贸网站建设、焉耆网络推广、微信小程序开发、焉耆网络营销、焉耆企业策划、焉耆品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;成都创新互联为所有大学生创业者提供焉耆建站搭建服务,24小时服务热线:18982081108,官方网址:www.cdcxhl.com
最近在Linux下编译C语言,用到gets这个函数,代码如下:
#include#include #include void main(){ char s[100]; // 存放输入的字符串 int i, j, n; printf("输入字符串:"); gets(s); n=strlen(s); for(i=0,j=n-1;i =j) printf("是回文串\n"); else printf("不是回文串\n"); } 

但是出现如下警告,
[linuxidc@localhost linuxidc.com]$ gcc linuxidc.c -o linuxidc.com
linuxidc.c: 在函数‘main'中:
linuxidc.c:8:5: 警告:不建议使用‘gets'(声明于 /usr/include/stdio.h:638) [-Wdeprecated-declarations]
gets(s);
^
/tmp/ccvwVatT.o:在函数‘main'中:
linuxidc.c:(.text+0x1f): 警告:the `gets' function is dangerous and should not be used.

问题解决
原因就在于,gets不会去检查字符串的长度,如果字符串过长就会导致溢出。如果溢出的字符覆盖了其他一些重要数据就会导致不可预测的后果。在man手册里也有关于gets这样的警告:
Never use gets(). Because it is impossible to tell without knowing the data in advance how many characters gets() will read, and because gets() will continue to store characters past the end of the buffer, it is extremely dangerous to use. It has been used to break computer security.
可以用scanf的扫描集来实现这一功能,只要在方括号中写入“^\n”,即:直到输入了回车才停止扫描。下面来演示这一用法:
#include#include #include void main(){ char s[100]; // 存放输入的字符串 int i, j, n; printf("输入字符串:"); scanf("%[^\n]",s); //改成这个就OK n=strlen(s); for(i=0,j=n-1;i =j) printf("是回文串\n"); else printf("不是回文串\n"); } 

OK,问题解决。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对创新互联的支持。