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