DEBUG模式下, 内存中的变量地址分析
测试函数的模板实现
- /// @file my_template.h
- /// @brief 测试数据类型用的模板实现
- #ifndef MY_TEMPLATE_H_2016_0123_1226
- #define MY_TEMPLATE_H_2016_0123_1226
- template<int iArySize>
- void fnTestDataType() {
- char szBuf[iArySize] = {'\0'};
- unsigned short wTmp = 0;
- int iTmp = 0;
- long lTmp = 0;
- float f = .0f;
- double dbl = .0;
- char szBuf1[iArySize] = {'\0'};
- unsigned short wTmp1 = 0;
- int iTmp1 = 0;
- long lTmp1 = 0;
- float f1 = .0f;
- double dbl1 = .0;
- printf("============================================================\n");
- printf("char array size = %d\n", iArySize);
- printf("------------------------------------------------------------\n");
- printf("&szBuf[0] = \t0x%p\n", &szBuf[0]);
- printf("&szBuf[%d] = \t0x%p\n", iArySize - 1, &szBuf[iArySize - 1]);
- printf("&wTmp = \t0x%p\n", &wTmp);
- printf("&iTmp = \t0x%p\n", &iTmp);
- printf("&lTmp = \t0x%p\n", &lTmp);
- printf("&f = \t\t0x%p\n", &f);
- printf("&dbl = \t\t0x%p\n", &dbl);
- printf("&szBuf1[0] = \t0x%p\n", &szBuf1[0]);
- printf("&szBuf1[%d] = \t0x%p\n", iArySize - 1, &szBuf1[iArySize - 1]);
- printf("&wTmp1 = \t0x%p\n", &wTmp1);
- printf("&iTmp1 = \t0x%p\n", &iTmp1);
- printf("&lTmp1 = \t0x%p\n", &lTmp1);
- printf("&f1 = \t\t0x%p\n", &f1);
- printf("&dbl1 = \t0x%p\n\n", &dbl1);
- };
- #endif // #ifndef MY_TEMPLATE_H_2016_0123_1226
测试代码和实验结论
- /// @file main.cpp
- /// @brief DEBUG模式下, 内存中的变量地址分析
- #include <iostream>
- using namespace std;
- #include "my_template.h"
- /** 试验结论 - <<DEBUG模式下, 内存中的变量地址分析>>
- 如果定义多个变量
- DEBUG模式下, 内存中的变量地址和定义的顺序相同
- 变量开始地址都是模式地址
- 先定义的变量在内存高地址
- 后定义的变量在内存低地址
- Release模式下, 经过优化, 变量的内存地址和变量定义的顺序不相同!
- 如果变量有越界访问的情况, Release模式下的越界访问情况未知.
- 好像有一些规律, 依赖于编译器的优化选项
- 依赖变量越界访问达成变量的存取, 在Release模式下会和Debug模式下的运行效果不相同.
- 运行结果肯定不对了. 是否报错,要看运气了. 如果不报错, 发布后会死的很惨
- */
- int main(int argc, char* argv[]) {
- /// 将函数模板特化的数组大小, 从1填到9来测试
- /// 不能直接在一个作用域内写多个函数模板的实例, 会全被替换成最后一个函数模板的实例
- fnTestDataType<9>();
- printf(""); //< bp
- /** IDE debug 变量内存地址分析
- ============================================================
- char array size = 9
- ------------------------------------------------------------
- &szBuf[0] = 0x0018FEE8
- &szBuf[8] = 0x0018FEF0
- &wTmp = 0x0018FEE4
- &iTmp = 0x0018FEE0
- &lTmp = 0x0018FEDC
- &f = 0x0018FED8
- &dbl = 0x0018FED0
- &szBuf1[0] = 0x0018FEC4
- &szBuf1[8] = 0x0018FECC
- &wTmp1 = 0x0018FEC0
- &iTmp1 = 0x0018FEBC
- &lTmp1 = 0x0018FEB8
- &f1 = 0x0018FEB4
- &dbl1 = 0x0018FEAC
- ============================================================
- char array size = 8
- ------------------------------------------------------------
- &szBuf[0] = 0x0018FEEC
- &szBuf[7] = 0x0018FEF3
- &wTmp = 0x0018FEE8
- &iTmp = 0x0018FEE4
- &lTmp = 0x0018FEE0
- &f = 0x0018FEDC
- &dbl = 0x0018FED4
- &szBuf1[0] = 0x0018FECC
- &szBuf1[7] = 0x0018FED3
- &wTmp1 = 0x0018FEC8
- &iTmp1 = 0x0018FEC4
- &lTmp1 = 0x0018FEC0
- &f1 = 0x0018FEBC
- &dbl1 = 0x0018FEB4
- ============================================================
- char array size = 7
- ------------------------------------------------------------
- &szBuf[0] = 0x0018FEEC
- &szBuf[6] = 0x0018FEF2
- &wTmp = 0x0018FEE8
- &iTmp = 0x0018FEE4
- &lTmp = 0x0018FEE0
- &f = 0x0018FEDC
- &dbl = 0x0018FED4
- &szBuf1[0] = 0x0018FECC
- &szBuf1[6] = 0x0018FED2
- &wTmp1 = 0x0018FEC8
- &iTmp1 = 0x0018FEC4
- &lTmp1 = 0x0018FEC0
- &f1 = 0x0018FEBC
- &dbl1 = 0x0018FEB4
- ============================================================
- char array size = 6
- ------------------------------------------------------------
- &szBuf[0] = 0x0018FEEC
- &szBuf[5] = 0x0018FEF1
- &wTmp = 0x0018FEE8
- &iTmp = 0x0018FEE4
- &lTmp = 0x0018FEE0
- &f = 0x0018FEDC
- &dbl = 0x0018FED4
- &szBuf1[0] = 0x0018FECC
- &szBuf1[5] = 0x0018FED1
- &wTmp1 = 0x0018FEC8
- &iTmp1 = 0x0018FEC4
- &lTmp1 = 0x0018FEC0
- &f1 = 0x0018FEBC
- &dbl1 = 0x0018FEB4
- ============================================================
- char array size = 5
- ------------------------------------------------------------
- &szBuf[0] = 0x0018FEEC
- &szBuf[4] = 0x0018FEF0
- &wTmp = 0x0018FEE8
- &iTmp = 0x0018FEE4
- &lTmp = 0x0018FEE0
- &f = 0x0018FEDC
- &dbl = 0x0018FED4
- &szBuf1[0] = 0x0018FECC
- &szBuf1[4] = 0x0018FED0
- &wTmp1 = 0x0018FEC8
- &iTmp1 = 0x0018FEC4
- &lTmp1 = 0x0018FEC0
- &f1 = 0x0018FEBC
- &dbl1 = 0x0018FEB4
- ============================================================
- char array size = 4
- ------------------------------------------------------------
- &szBuf[0] = 0x0018FEF0
- &szBuf[3] = 0x0018FEF3
- &wTmp = 0x0018FEEC
- &iTmp = 0x0018FEE8
- &lTmp = 0x0018FEE4
- &f = 0x0018FEE0
- &dbl = 0x0018FED8
- &szBuf1[0] = 0x0018FED4
- &szBuf1[3] = 0x0018FED7
- &wTmp1 = 0x0018FED0
- &iTmp1 = 0x0018FECC
- &lTmp1 = 0x0018FEC8
- &f1 = 0x0018FEC4
- &dbl1 = 0x0018FEBC
- ============================================================
- char array size = 3
- ------------------------------------------------------------
- &szBuf[0] = 0x0018FEF0
- &szBuf[2] = 0x0018FEF2
- &wTmp = 0x0018FEEC
- &iTmp = 0x0018FEE8
- &lTmp = 0x0018FEE4
- &f = 0x0018FEE0
- &dbl = 0x0018FED8
- &szBuf1[0] = 0x0018FED4
- &szBuf1[2] = 0x0018FED6
- &wTmp1 = 0x0018FED0
- &iTmp1 = 0x0018FECC
- &lTmp1 = 0x0018FEC8
- &f1 = 0x0018FEC4
- &dbl1 = 0x0018FEBC
- ============================================================
- char array size = 2
- ------------------------------------------------------------
- &szBuf[0] = 0x0018FEF0
- &szBuf[1] = 0x0018FEF1
- &wTmp = 0x0018FEEC
- &iTmp = 0x0018FEE8
- &lTmp = 0x0018FEE4
- &f = 0x0018FEE0
- &dbl = 0x0018FED8
- &szBuf1[0] = 0x0018FED4
- &szBuf1[1] = 0x0018FED5
- &wTmp1 = 0x0018FED0
- &iTmp1 = 0x0018FECC
- &lTmp1 = 0x0018FEC8
- &f1 = 0x0018FEC4
- &dbl1 = 0x0018FEBC
- ============================================================
- char array size = 1
- ------------------------------------------------------------
- &szBuf[0] = 0x0018FEF0
- &szBuf[0] = 0x0018FEF0
- &wTmp = 0x0018FEEC
- &iTmp = 0x0018FEE8
- &lTmp = 0x0018FEE4
- &f = 0x0018FEE0
- &dbl = 0x0018FED8
- &szBuf1[0] = 0x0018FED4
- &szBuf1[0] = 0x0018FED4
- &wTmp1 = 0x0018FED0
- &iTmp1 = 0x0018FECC
- &lTmp1 = 0x0018FEC8
- &f1 = 0x0018FEC4
- &dbl1 = 0x0018FEBC
- */
- printf("END, press any key to quit\n");
- return 0;
- }
http://blog.csdn.net/lostspeed/article/details/50569619
DEBUG模式下, 内存中的变量地址分析的更多相关文章
- eclipse在debug模式下鼠标移动到变量上不显示值的问题
在eclipse中调试时,鼠标移动到变量上不显示值,使用ctrl+shift+i,或者通过配置达到目的: Window->Preferences->Java->Editor-> ...
- 引入 Tinker 之后如何在 Debug 模式下开启 Instant Run
在<Tinker + Bugly + Jenkins 爬坑之路>一文中讲了在接入 Tinker 之后,Jenkins 中的一些坑,由此,热修复算告一段落,但是,在直接 Run 模式运行时, ...
- Debug模式下编译溢出问题
问题: 代码在Debug模式下编译报出内存溢出的错误,而Release模式下则没有. 由于Debug模式下包含调试信息,并且不作任何优化.而Release模式进行了各种优化,内存检测等操作均省去,使得 ...
- C++程序在debug模式下遇到Run-Time Check Failure #0 - The value of ESP was not properly saved across a function call问题。
今天遇到一个Access Violation的crash,只看crash call stack没有找到更多的线索,于是在debug模式下又跑了一遍,遇到了如下的一个debug的错误提示框: 这个是什么 ...
- Mach-O在内存中符号表地址、字符串表地址的计算
KSCrash 是一个用于 iOS 平台的崩溃捕捉框架,最近读了其部分源码,在 KSDynamicLinker 文件中有一个函数,代码如下: /** Get the segment base addr ...
- 重写NSLog,Debug模式下打印日志和当前行数
在pch文件中加入以下命令,NSLog在真机测试中就不会打印了 //重写NSLog,Debug模式下打印日志和当前行数 #if DEBUG #define NSLog(FORMAT, ...) fpr ...
- Intellij IDEA debug模式下项目启动慢/无法启动的事件解决过程记录
项目无法启动了 简单的介绍一下事件过程:周一的早上,收到前端同事抛过来的一个任务,说是一个接口无法正常返回数据,于是就让他把参数发过来,我想试着在本地重现一下并且将问题修复掉,这种情况肯定是要通过de ...
- Myeclipse在debug模式下没加断点程序卡住,start模式下可以正常启动
参考<eclipse在debug模式下卡住,start模式下可以启动>,地址:https://blog.csdn.net/jack_chen1994/article/details/761 ...
- eclipse的debug模式下启动不了tomcat
使用eclipse启动tomcat,正常模式下可以启动tomcat,却在debug模式下无法启动tomcat. 这个问题可能是由于eclipse和tomcat的交互而产生的,在以debug模式启动to ...
随机推荐
- iOS中正确的截屏姿势
昨天写了个用到截屏功能的插件,结果问题不断,今天终于解决好了,把debug过程中所有尝试过的截屏方法都贴出来吧- 第一种 这是iOS 3时代开始就被使用的方法,它被废止于iOS 7.iOS的私有方法, ...
- U3D学习笔记
1.向量的点乘.叉乘以及归一化的意义 1)点乘描述了两个向量的相似程度,结果越大两向量越相似,还可表示投影 2)叉乘得到的向量垂直于原来的两个向量 3)标准化向量:用在只关系方向,不关心大小的时候 用 ...
- 【QT相关】QT+opencv环境配置
在qt msvc2010版软件中使用opencv2.4.9进行库函数配置.仅适用于windows下. INCLUDEPATH += $$PWD/../../../opencv/build/includ ...
- junit4笔记
这两天在复习hibernate,看的小峰的视频,觉得很不错. 现在把里面的junit4的一些使用方法记下来.方便以后的差用.代码如下. package com.java1234.service; im ...
- JVM 重排序
在java代码到最终执行的指令序列的整个过程中,会出现重排序.也就是说最终执行的顺序并不是按照源代码执行的顺序来进行的. 其中1为编译器的优化重排序,2,3是处理器的重排序. 数据依赖 如果两个操作访 ...
- 转:一道笔试题-将int型数组强制转换为char*,再求strlen,涉及大小端
写出如下程序运行结果: #include<stdio.h> #include<string.h> int main() { int a[2000]; char *p = (ch ...
- 2、Zookeeper集群搭建、命令行Client操作
zookeeper 集群最好是奇数台: 5台允许挂掉2台 4台只能允许挂掉1台 zjtest7-redis:/opt/zookeeper/bin# ./zkServer.sh status ZooKe ...
- 解决Android Activity切换时出现白屏问题
有些性能低的机器,在切换activity时候出现白屏一段时候后才显示正确的视图 高性能的机器可能太快看不到,但是事实是存在的, 特别是当你新开一个进程的时候,A进程的activity跳转到B进程的Ac ...
- Oracle 11g RAC OCR 与 db_unique_name 配置关系 说明
一. 问题一 在做RAC standby 的alert log里发现如下错误: SUCCESS: diskgroup DATA was mounted ERROR: failed toestablis ...
- MSSql跨数据库查询
select d.PostTime ,l.name from DatabaseLog d ,lumigent.dbo.test l 一定要加.dbo,不加dbo不行啊 select * from lu ...