1. #include <iostream>
    2. #include <limits>
    3. using namespace std;
    4. #define SAFE_DELETE(x) \
    5. { \
    6. if (NULL != (x)) \
    7. { \
    8. delete (x); \
    9. (x) = NULL; \
    10. } \
    11. }
    12. #define SAFE_DELETE_ARY(x) \
    13. { \
    14. if (NULL != (x)) \
    15. { \
    16. delete[] (x); \
    17. (x) = NULL; \
    18. } \
    19. }
    20. class CA
    21. {
    22. public:
    23. CA()
    24. {
    25. setter_m_iTest(-1);
    26. }
    27. ~CA() {}
    28. void setter_m_iTest(int iIn) {m_iTest = iIn;}
    29. int getter_m_iTest() {return m_iTest;}
    30. private:
    31. int m_iTest;
    32. };
    33. void fnTestClass();
    34. void clear_cin();
    35. int main(int argc, char** argv, char** envp)
    36. {
    37. fnTestClass();
    38. cout << "END, press any key to quit" << endl;
    39. clear_cin();
    40. getchar();
    41. return 0;
    42. }
    43. void fnTestClass()
    44. {
    45. int i = 0;
    46. int iTmp = 0;
    47. const int iCntAry = 4;
    48. CA* pCaAry = NULL;
    49. CA* pCa = NULL;
    50. /** new 单个对象时的内存布局
    51. +   pCa 0x00883e30
    52. 00883E30  01 00 00 00  .... ///< pCa
    53. */
    54. pCa = new CA;
    55. if (NULL != pCa)
    56. {
    57. pCa->setter_m_iTest(1);
    58. SAFE_DELETE(pCa); ///< delete后, 原来的数据变为 EE FE EE FE
    59. }
    60. /** new对象数组时的内存布局
    61. +   pCaAry  0x007d3ddc
    62. 007D3DD8  04 00 00 00  .... ; ///< 类数组元素个数 = 4
    63. 007D3DDC  00 00 00 00  .... ; ///< 类数组开始, CA[0]
    64. 007D3DE0  01 00 00 00  .... ; ///< CA[1]
    65. 007D3DE4  02 00 00 00  .... ; ///< CA[2]
    66. 007D3DE8  03 00 00 00  .... ; ///< CA[3]
    67. */
    68. pCaAry = new CA[iCntAry];
    69. if (NULL != pCaAry)
    70. {
    71. for (i = 0; i < iCntAry; i++)
    72. {
    73. pCaAry[i].setter_m_iTest(i);
    74. }
    75. }
    76. SAFE_DELETE_ARY(pCaAry);
    77. /** 手工模拟delete删除单个对象
    78. */
    79. pCa = new CA;
    80. if (NULL != pCa)
    81. {
    82. pCa->setter_m_iTest(1);
    83. if (NULL != pCa)
    84. {
    85. pCa->~CA();
    86. free(pCa); ///< ok
    87. pCa = NULL;
    88. }
    89. }
    90. /** 手工模拟delete删除对象数组
    91. 会报错, 和实际情况不同
    92. 以后再研究 :(
    93. */
    94. // 会报错, 和实际情况不同
    95. //     pCaAry = new CA[iCntAry];
    96. //     if (NULL != pCaAry)
    97. //     {
    98. //         iTmp = *((int*)pCaAry - 1);
    99. //         for (i = 0; i < iTmp; i++)
    100. //         {
    101. //             pCaAry[i].setter_m_iTest(i);
    102. //             pCaAry[i].~CA();
    103. //         }
    104. //
    105. //         free(pCaAry); ///< ! crash
    106. //         pCaAry = NULL;
    107. //     }
    108. // 会报错, 和实际情况不同
    109. //     pCaAry = new CA[iCntAry];
    110. //     if (NULL != pCaAry)
    111. //     {
    112. //         iTmp = *((int*)pCaAry - 1);
    113. //         for (i = 0; i < iTmp; i++)
    114. //         {
    115. //             pCaAry[i].setter_m_iTest(i);
    116. //             pCaAry[i].~CA();
    117. //             free(pCaAry + i); ///< ! crash
    118. //         }
    119. //
    120. //         pCaAry = NULL;
    121. //     }
    122. }
    123. void clear_cin()
    124. {
    125. cin.clear();
    126. cin.sync();
    127. }

http://blog.csdn.net/lostspeed/article/details/50300867

new对象数组时的内存布局的更多相关文章

  1. 关于Class对象、类加载机制、虚拟机运行时的内存布局的全面解析和推测

    简介: 本文是对Java的类加载机制,Class对象,反射原理等相关概念的理解.验证和Java虚拟机中内存布局的一些推测.本文重点讲述了如何理解Class对象以及Class对象的作用. 欢迎探讨,如有 ...

  2. Java中对象创建时的内存分配

    一.前言知识铺垫   1.逃逸对象:在一个方法内创建的对象没有被外界引用则称该对象为未逃逸的对象. 2.JDK1.6以后的HotSpot虚拟机支持运行时的对象逃逸分析. 3.JVM中的参数配置: 1) ...

  3. Java对象的创建、内存布局和访问定位

    在Java运行时数据区中,我们知道了虚拟机内存的概况,本文介绍虚拟机内存中的数据的其它细节,如对象如何创建.如何布局以及如何访问. 基于实用的原则,这里以HotSpot虚拟机和常用的内存区域Java堆 ...

  4. 【深入理解JVM】:Java对象的创建、内存布局、访问定位

    对象的创建 一个简单的创建对象语句Clazz instance = new Clazz();包含的主要过程包括了类加载检查.对象分配内存.并发处理.内存空间初始化.对象设置.执行ini方法等. 主要流 ...

  5. 【JVM第六篇--对象】对象的实例化、内存布局和访问定位

    写在前面的话:本文是在观看尚硅谷JVM教程后,整理的学习笔记.其观看地址如下:尚硅谷2020最新版宋红康JVM教程 一.对象的实例化 在平常写代码的过程中,我们用class关键字定义的类只是一个类的模 ...

  6. 理解Java对象:要从内存布局及底层机制说起,话说….

    前言 大家好,又见面了,今天是JVM专题的第二篇文章,在上一篇文章中我们说了Java的类和对象在JVM中的存储方式,并使用HSDB进行佐证,没有看过上一篇文章的小伙伴可以点这里:<类和对象在JV ...

  7. java面试-对象的创建、内存布局、访问定位

    一.对象的创建 1.虚拟机遇到一条new指令时,首先将去检查这个指令的参数是否能在常量池中定位到一个类的符号引用,并且检查这个符号引用代表的类是否已被加载.解析和初始化过.如果没有,那必须先执行相应的 ...

  8. JVM详解(六)——对象的实例化、内存布局与访问定位

    一.对象的实例化 1.创建对象的方式 2.创建对象的步骤 脑图:https://www.processon.com/view/link/61701a927d9c087040525226 3.对象属性赋 ...

  9. 深入理解Java虚拟机(二)、Java对象的创建,内存布局和访问定位

    对象的创建: Object obj = new Object(); 常量池中是否有Ljava.lang.Object

随机推荐

  1. HDoj-1527-取石子游戏

    取石子游戏 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Subm ...

  2. 案例分析:java中substring引发的Full gc

    问题定位 由于应用频繁地Full gc,就dump了内存下来用MAT分析,发现有个map占用了98%的内存,于是找到这个map private ConcurrentMap<String, Str ...

  3. GitHub的问题

    出现failed to publish the branch, 转自:http://blog.csdn.net/cucmakeit/article/details/29407329 (windows系 ...

  4. IEEE浮点数float、double的存储结构

    众所周知,C的float.VB的Single都是32位浮点数变量类型(也叫单精度浮点数),C的double和VB的Double则都是64位的浮点数变量类型(也叫双精度浮点数).有些编译器还支持更屌的l ...

  5. QT5.6 编译SQLServer驱动

    简要说下编译的主要步骤 @1:打开vs2015的命令行编译环境 ‘ @2:进入到cd到源码目录:cd C:\Qt\Qt5.6.0\5.6\Src\qtbase\src\plugins\sqldrive ...

  6. springmvc-3.2-jsr303解决服务端验证问题

    从以前的验证:Stringutils.isEmpty....到struts的验证:xxxvalidate 现在使用jsr303使之更加简单  依赖hibernate-validator-4.xx.ja ...

  7. 【HTTP 2】HTTP/2 协议概述(HTTP/2 Protocol Overview)

    前情提要 在上一篇文章<[HTTP 2.0] 简介(Introduction)>中,我们简单介绍了 HTTP 2. 在本篇文章中,我们将会了解到 HTTP 2 协议概述部分的内容. HTT ...

  8. Android 文件共享服务器

    http://download.csdn.net/detail/liduanw/6271075 你可以将自己的手机作为(局域网)服务器,  使用方法: 1> 指定共享根目录 2> 点击启动 ...

  9. poj1920 Towers of Hanoi

    关于汉诺塔的递归,记住一个结论是,转移n个盘子至少需要2^n-1步 #include<iostream> #include<cstdio> #include<cmath& ...

  10. Android SurfaceView实战 带你玩转flabby bird (上)

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/42965779 ,本文出自:[张鸿洋的博客] 1.概述 哈,记得以前写过Andro ...