浅析错误 Run-Time Check Failure #2 - Stack around the variable ‘a‘ was corrupted
发布日期:2021-07-01 04:04:05
浏览次数:3
分类:技术文章
本文共 1694 字,大约阅读时间需要 5 分钟。
浅析错误 Run-Time Check Failure #2 - Stack around the variable 'a' was corrupted
问题叙述
最近在写循环嵌套的时候老是报错:Run-Time Check Failure #2 - Stack around the variable ‘a’ was corrupted
百思不得其解,循环没有问题,网上查找错误,都说是内存越界造成的,于是各种扩大数组大小,仍然报错。
以下是测试程序:#includeusing namespace std;#define MAX_AXES 4int main(){ int axispos[MAX_AXES]; int axisvel[MAX_AXES]; int time[10] = { 0 }; for (int i = 0; i < MAX_AXES; i++) { axispos[i] = i; axisvel[i] = i; } int a[10 * (MAX_AXES * 2 + 1)]; for (int i = 0; i < 10; i++) { a[i*(2 * MAX_AXES + 1)] = time[i]; cout << a[i*(2 * MAX_AXES + 1)] << "|"; for (int j = 0; j < MAX_AXES; j++) { a[i*(2 * MAX_AXES + 1)+2*j-1] = axispos[j]; a[i*(2 * MAX_AXES + 1) + 2 * j] = axisvel[j]; cout << a[i*(2 * MAX_AXES + 1) + 2 * j - 1] << "|" << a[i*(2 * MAX_AXES + 1) + 2 * j] << "|"; } cout << endl; } return 0;}
在老王大腿的指导下,找到了问题所在。
在第2层循环中,有一句a[i*(2 * MAX_AXES + 1)+2*j-1] = axispos[j];
,当i,j都为0的时候,a的索引变成了-1,于是引起数组越界问题。 解决方案
把循环从0开始换成从1开始
#includeusing namespace std;#define MAX_AXES 4int main(){ int axispos[MAX_AXES]; int axisvel[MAX_AXES]; int time[20] = { 0 }; for (int i = 0; i < MAX_AXES; i++) { axispos[i] = i; axisvel[i] = i; } int a[10 * (MAX_AXES * 2 + 1)]; for (int i = 0; i < 10; i++) { a[i*(2 * MAX_AXES + 1)] = time[i]; cout << a[i*(2 * MAX_AXES + 1)] << "|"; for (int j = 1; j <= MAX_AXES; j++) /// { a[i*(2 * MAX_AXES + 1)+2*j-1] = axispos[j-1]; a[i*(2 * MAX_AXES + 1) + 2 * j] = axisvel[j-1]; cout << a[i*(2 * MAX_AXES + 1) + 2 * j - 1] << "|" << a[i*(2 * MAX_AXES + 1) + 2 * j] << "|"; } cout << endl; } return 0;}
为什么各种尝试都没有发现?原因在于形成了定式思维,一说超限首先想到的是上界超限,于是开始钻牛角尖………………
结论
- 定式思维要不得!!!!
转载地址:https://miracle.blog.csdn.net/article/details/93471395 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
哈哈,博客排版真的漂亮呢~
[***.90.31.176]2024年04月30日 18时21分32秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
c语言细读之static auto
2019-05-02
ffmpeg开发中的问题(九)
2019-05-02
leetcode-longest common prefix
2019-05-02
tinyhttpd源码学习1
2019-05-02
九度题目1015:还是A+B
2019-05-02
Mongoose API Reference
2019-05-02
hdu2568
2019-05-02
九度题目1505:两个链表的第一个公共结点
2019-05-02
linux下intel 82579LM 网卡驱动安装
2019-05-02
ffmpeg开发中的问题(十二) 一些小点
2019-05-02
python urllib
2019-05-02
APUE初学 环境搭建
2019-05-02
Binary Tree Level Order Traversal
2019-05-02
题目1511:从尾到头打印链表
2019-05-02
SYSTEM V IPC 基本概念
2019-05-02
Elasticsearch 备份数据到 AWS S3
2019-05-02
使用rancher配置kong和konga
2019-05-02
变量字符串${var%%.*}
2019-05-02
Kong docker部署及简单使用
2019-05-02
jstat命令查看jvm的GC情况
2019-05-02