2 cnw2015 cnw2015 于 2016.02.20 22:35 提问

新人求好心好心大神帮帮忙 Visual C遇到char溢出问题

我遇到一个好纠结的问题,一直不知道原因在哪,蛋都碎了:

主工程:
char Msg[1024];
check(Msg);//dll
Addstring(Msg);

DLL:
int check(*msg)
{
cstring buff="";
strcpy(msg,"");
buff.format("xxxxxx%d,%d",int1,int2);
strcat(msg,"buff");
buff.format("xxxxxx%d,%d",int3,int4);
strcat(msg,"buff");
...
buff.format("xxxxxx%d,%d",intx,inty);
strcat(msg,"buff");

return 1
}

代码如上,问题是:
DLL没有异常,在运行至主工程Addstring(Msg)时会错误;
检查发现控制Msg大小在512以内时可以正常运行,超出512则会报错。
但主工程已经定义1024空间了呀?
请问这是为什么呢??

5个回答

mengyin521
mengyin521   2016.02.21 10:36
已采纳

代码不完整 ,你的项目中其他地方 肯定有 比较明显的BUG

caozhy
caozhy   Ds   Rxr 2016.02.21 06:47

一个整数,本身占4个字节,但是格式化成字符串,最多可以变成11个字节(比如-2100000000)
每次strcat又会消耗不少,取决于buff格式化的长度。
你最好调试下。

你贴出来的代码不是最终的程序,而是你手写的吧。错误百出,strcat(msg,"buff");明显buff没有引号。xxxxx到底是多少,你strcat了几次,都不得而知了。

cnw2015
cnw2015   2016.02.21 10:02

@caozhy 有调试int cnt = strlen(Msg)计算Msg长度,发现超过512时Msg长度不会继续增加。
代码确实是手敲的,buff没有引号。

cnw2015
cnw2015   2016.02.22 17:46

多谢,原因找到了,addstring的buf限制在了512图片说明

fk002008
fk002008   2016.02.21 01:22

主工程已经定义1024空间
int check(*msg)这个函数里面strcat(msg,"buff");
已经占用了MSG的一部分空间,所以check之后这个msg的剩余空间是不是不够了啊

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!