c语言容易出现的漏洞函数 c语言容易出错的问题
c语言:如图,请问一下哪里出错了?
首先解答一下这个C语言代码出错的原因:
目前成都创新互联已为数千家的企业提供了网站建设、域名、虚拟空间、网站托管维护、企业网站设计、福贡网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。
第一个gets未定义:
出现这个错误一般是没有包含相应的头文件,或者库里没有这个函数。这里应该是没有这个函数。gets(char *dest)是一个老的库函数,采用这个函数存在越界的安全隐患。它只有一个参数,如果输入的字符个数超过dest内存空间,程序可能失败,也可能被黑客利用这个漏洞进行不正常操作。可以使用fgets(char *dest, int size, FILE *fp)代替,它可以通过第二个参数设置最大输入解决上面的问题。
第二/三个strcat参数2类型不符:
strcat的第二个参数语言char *,而调用时jiji[i]是char,可以写成jiji[i],改完语法没有问题,逻辑要再自己评估一下。
第四个返回局部变量re:
re是lai函数内部的数组,在栈内,当函数执行完会进行释放资源。其栈内的空间可能用于它处,内容可能被改变。建议是不要返回局部变量。
以上就是这个代码语法出错的解答。
另外补充一下:
整体来看这段代码代码比较长,for循环也比较多,后续再优化一下。先实现功能再优化。下面这个代码你可以参考。
关于c语言printf 与scanf问题 漏洞
这个是可以实现的,这样就行。#include#include#include#includeintmain(){intn;printf("请输入数字:【】\b\b");scanf("%d",n);}\b是退格符号。因为“【】”是中文符号,所以占得字节数与英文字符不一样。你自己可以调一下格式。而且这儿还有一个关键的问题,就是当“【】”内的内容够长时,就会把后面的括号“】”覆盖掉。你可以自己试一下
为什么C语言的strcpy函数有漏洞
strcpy将源字符串拷贝到目标字符串时,并不检查目标字符串的长度,如果源字符串过长会导致目标内存后面的空间被覆盖
文章标题:c语言容易出现的漏洞函数 c语言容易出错的问题
本文路径:http://pwwzsj.com/article/dddogeo.html