Run-Time Check Failure #2 - Stack around the variable 'var' was corrupted
摘要:
简介VC++.NET编译新功能,运行时错误检查,编译选项 (/RTC1, equiv. to /RTCsu)
最近把一个别人早期在VC 6下编写的一个服务移植到VC 7.1 (.NET 2003)时,突然跳出
好些运行时错误提示。
经过查询编译器和出错说明,发现了编译器的这一新特性,并修正了代码隐患:
//someheadefile.h
typedef struct tarSomeMessagePack
{
char moibleNumber[20];
....
}SomeMessagePack_T,*SomeMessagePack_Ptr;
细心的开发者可能已经发现,这里使用字符串数组下标越界了。即mobileNumber[]有效元素
下标为0到19,mobileNumber[20]是非法的。在VC 6下,编译运行并没有处任何问题,这也结
构体在内存字节对齐也有关系,实际上,mobileNumber[]在默认与8字节对齐的环境下编译链
接的,因此,后4个bit也不会被系统用到,即mobileNumber[20],mobileNumber[21],
mobileNumber[22],mobileNumber[23]系统把它空着。
尽管系统运行同几年都很正常,但
strncpy(pack.mobileNumber," ",20);
这样的代码也是危险的代码,要是有一天,把这个结构体字节对齐方式改为1,那么程序一定
在这里崩溃。
VC7.1为我们提供了一种机制,在编译选项中,增加(/RTC1, equiv. to /RTCsu)项选。当程序
运行到这里的时候,即会向我们报告这一错误。
查看相关文档,了解了这一块代码的真实意图后,我把代码改为
strncpy(pack.mobileNumber," ",19);
这一问题消失。
//someimplement.cpp
strncpy(pack.mobileNumber," ",20);
分享到:
相关推荐
HASP按照文件解决H0033错误,Unable to access HASP SRM Run-time Environment? (H0033)
Sentinel_LDK_Run-time_setup8.15
Sentinel_LDK_Run-time_setup_7.92
EPLAN需要用最新版加密狗,兼容win10 21H2
Sentinel_LDK_Run-time_cmd_line_6.50.zip
开源项目-pingcap-tidb#run-as-mysql-protocol-server.zip,tidb mysql协议服务器已经发布,现在可以运行wordpress了。
emulator doongle hasp hasp4 hasp srm
arcgis visual fortran run-time error解决办法
Pascal的详细介绍
解决Windows10 20H2安装ePlan P8 2.5 2.7过程中,安装MultiKey蓝屏和黄色感叹号问题。亲测可用,看到这个资源前你肯定尝试了很多办法了,stp1:先cd到ePlan自带的驱动目录“ELM/../Drivers/”下运行以下命令...
Chinese-Text-Classification-Pytorch-master。 数据齐全,说明文档详细。... # 训练并测试: # TextCNN python run.py --model TextCNN # TextRNN python run.py --model TextRNN ...python run.py --model Transformer