new对象数组时的内存布局
- #include <iostream>
- #include <limits>
- using namespace std;
- #define SAFE_DELETE(x) \
- { \
- if (NULL != (x)) \
- { \
- delete (x); \
- (x) = NULL; \
- } \
- }
- #define SAFE_DELETE_ARY(x) \
- { \
- if (NULL != (x)) \
- { \
- delete[] (x); \
- (x) = NULL; \
- } \
- }
- class CA
- {
- public:
- CA()
- {
- setter_m_iTest(-1);
- }
- ~CA() {}
- void setter_m_iTest(int iIn) {m_iTest = iIn;}
- int getter_m_iTest() {return m_iTest;}
- private:
- int m_iTest;
- };
- void fnTestClass();
- void clear_cin();
- int main(int argc, char** argv, char** envp)
- {
- fnTestClass();
- cout << "END, press any key to quit" << endl;
- clear_cin();
- getchar();
- return 0;
- }
- void fnTestClass()
- {
- int i = 0;
- int iTmp = 0;
- const int iCntAry = 4;
- CA* pCaAry = NULL;
- CA* pCa = NULL;
- /** new 单个对象时的内存布局
- + pCa 0x00883e30
- 00883E30 01 00 00 00 .... ///< pCa
- */
- pCa = new CA;
- if (NULL != pCa)
- {
- pCa->setter_m_iTest(1);
- SAFE_DELETE(pCa); ///< delete后, 原来的数据变为 EE FE EE FE
- }
- /** new对象数组时的内存布局
- + pCaAry 0x007d3ddc
- 007D3DD8 04 00 00 00 .... ; ///< 类数组元素个数 = 4
- 007D3DDC 00 00 00 00 .... ; ///< 类数组开始, CA[0]
- 007D3DE0 01 00 00 00 .... ; ///< CA[1]
- 007D3DE4 02 00 00 00 .... ; ///< CA[2]
- 007D3DE8 03 00 00 00 .... ; ///< CA[3]
- */
- pCaAry = new CA[iCntAry];
- if (NULL != pCaAry)
- {
- for (i = 0; i < iCntAry; i++)
- {
- pCaAry[i].setter_m_iTest(i);
- }
- }
- SAFE_DELETE_ARY(pCaAry);
- /** 手工模拟delete删除单个对象
- */
- pCa = new CA;
- if (NULL != pCa)
- {
- pCa->setter_m_iTest(1);
- if (NULL != pCa)
- {
- pCa->~CA();
- free(pCa); ///< ok
- pCa = NULL;
- }
- }
- /** 手工模拟delete删除对象数组
- 会报错, 和实际情况不同
- 以后再研究 :(
- */
- // 会报错, 和实际情况不同
- // pCaAry = new CA[iCntAry];
- // if (NULL != pCaAry)
- // {
- // iTmp = *((int*)pCaAry - 1);
- // for (i = 0; i < iTmp; i++)
- // {
- // pCaAry[i].setter_m_iTest(i);
- // pCaAry[i].~CA();
- // }
- //
- // free(pCaAry); ///< ! crash
- // pCaAry = NULL;
- // }
- // 会报错, 和实际情况不同
- // pCaAry = new CA[iCntAry];
- // if (NULL != pCaAry)
- // {
- // iTmp = *((int*)pCaAry - 1);
- // for (i = 0; i < iTmp; i++)
- // {
- // pCaAry[i].setter_m_iTest(i);
- // pCaAry[i].~CA();
- // free(pCaAry + i); ///< ! crash
- // }
- //
- // pCaAry = NULL;
- // }
- }
- void clear_cin()
- {
- cin.clear();
- cin.sync();
- }
http://blog.csdn.net/lostspeed/article/details/50300867
new对象数组时的内存布局的更多相关文章
- 关于Class对象、类加载机制、虚拟机运行时的内存布局的全面解析和推测
简介: 本文是对Java的类加载机制,Class对象,反射原理等相关概念的理解.验证和Java虚拟机中内存布局的一些推测.本文重点讲述了如何理解Class对象以及Class对象的作用. 欢迎探讨,如有 ...
- Java中对象创建时的内存分配
一.前言知识铺垫 1.逃逸对象:在一个方法内创建的对象没有被外界引用则称该对象为未逃逸的对象. 2.JDK1.6以后的HotSpot虚拟机支持运行时的对象逃逸分析. 3.JVM中的参数配置: 1) ...
- Java对象的创建、内存布局和访问定位
在Java运行时数据区中,我们知道了虚拟机内存的概况,本文介绍虚拟机内存中的数据的其它细节,如对象如何创建.如何布局以及如何访问. 基于实用的原则,这里以HotSpot虚拟机和常用的内存区域Java堆 ...
- 【深入理解JVM】:Java对象的创建、内存布局、访问定位
对象的创建 一个简单的创建对象语句Clazz instance = new Clazz();包含的主要过程包括了类加载检查.对象分配内存.并发处理.内存空间初始化.对象设置.执行ini方法等. 主要流 ...
- 【JVM第六篇--对象】对象的实例化、内存布局和访问定位
写在前面的话:本文是在观看尚硅谷JVM教程后,整理的学习笔记.其观看地址如下:尚硅谷2020最新版宋红康JVM教程 一.对象的实例化 在平常写代码的过程中,我们用class关键字定义的类只是一个类的模 ...
- 理解Java对象:要从内存布局及底层机制说起,话说….
前言 大家好,又见面了,今天是JVM专题的第二篇文章,在上一篇文章中我们说了Java的类和对象在JVM中的存储方式,并使用HSDB进行佐证,没有看过上一篇文章的小伙伴可以点这里:<类和对象在JV ...
- java面试-对象的创建、内存布局、访问定位
一.对象的创建 1.虚拟机遇到一条new指令时,首先将去检查这个指令的参数是否能在常量池中定位到一个类的符号引用,并且检查这个符号引用代表的类是否已被加载.解析和初始化过.如果没有,那必须先执行相应的 ...
- JVM详解(六)——对象的实例化、内存布局与访问定位
一.对象的实例化 1.创建对象的方式 2.创建对象的步骤 脑图:https://www.processon.com/view/link/61701a927d9c087040525226 3.对象属性赋 ...
- 深入理解Java虚拟机(二)、Java对象的创建,内存布局和访问定位
对象的创建: Object obj = new Object(); 常量池中是否有Ljava.lang.Object
随机推荐
- C语言 结构体数组保存到二进制文件中
在项目中我定义了一个结构体数组,头文件如下: C/C++ code ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 ...
- objective-III 窗口应用程序
objective-III 一.创建窗口应用程序 打开xcode->create->在iso目录下选择empty-null->创建 在打开的项目文件名上右击NEW FILE,在io ...
- [POJ 2184]--Cow Exhibition(0-1背包变形)
题目链接:http://poj.org/problem?id=2184 Cow Exhibition Time Limit: 1000MS Memory Limit: 65536K Total S ...
- ios改变系统默认样式
iso系统下默认不能修改submit样式,于是加上如下属性就可以修改: -webkit-appearance:none; -moz-appearance:none; 先记录下.
- 解决Spring中singleton的Bean依赖于prototype的Bean的问题
在spring bean的配置的时候,可能会出现一个singleton的bean依赖一个prototype的bean.因为singleton的bean只有一次初始化的机会,所以他们的依赖关系页只有在初 ...
- C语言循环剖析(转载)
一.if.else float变量与“零值”进行比较: float fTestVal = 0.0; if((fTestVal >= -EPSINON) && (fTestVal ...
- 在DE1-SOC上运行Linux
1,设定串口终端 安装驱动 :使用mini-USB线将计算机与DE1-SoC的UART转USB接口.drivers\USB2UART_driver文件夹内放置有驱动程序 设定串口终端规格 : 设定串口 ...
- 字符串如何判断null.
转http://blog.sina.com.cn/s/blog_48cd37140101awgq.html Java中判断String不为空的问题 一.判断一个字符串str不为空的方法有: 1. st ...
- 区间重合判断(pojg校门外的树)
pojg:http://poj.grids.cn/practice/2808 解法1:以空间换时间: #include<stdio.h> #include<string.h> ...
- wget -r -nc -np "http://www.zhihu.com/"
下载网站所有 -r, --recursive specify recursive download. -nc, --no-clobber skip dow ...