C++中的内存区域及其性能特征
首先须要指出的是。我们通经常使用“堆”和“自由存储”这两个术语来区分两种不同类型的动态分配内存。
1.常量数据:常量数据区域主要用于存储字符串以及其它在编译期就已经知道值的数据。实例化的对象是不能存储在 这 个区域中的。
在程序的整个生存期内。这个区域中的全部数据都是有效的。而且,全部这些数据都是仅仅读的,假设对这些数据进行改动。其结果在C++中是未定义的。
造成这样的后果的部分原因是编译器可能会对常量数据的基本存储格式进行随意优化。
比如,在某个特定的编译器中,可能会将字符串常量保存在重叠对象内以进行优化。
2.栈:在栈中存储的是自己主动变量。
自己主动变量在定义的时候被马上构造,而且在自己主动变量作用域结束的时候被马上销毁,因此程序猿无法对已经分配但尚未初始化的栈空间直接进行操作(除非你有意识地使用显示析构函数和布局new语法)。
栈内存的分配通常要比动态内存的分配(堆和自由存储)快非常多,由于每次栈内存的分配仅仅涉及栈指针的自增操作,而无需进行更为复杂的内存管理。
3.自由存储:自由存储时两种动态内存区域之中的一个。它是通过new/delete来分别进行分配/释放。
对象的生存期可能会小于所分配的存储空间的生存期。
也就是说,自由存储区域中的对象在分配内存时并不要求马上进行初始化。而且在销毁对象时。也不要求马上释放内存空间。
在存储空间已经被分配但还没有进入到对象生存期的这段时间内,我们能够通过一个void*类型的指针来訪问和操作这块存储空间。但我们不能訪问对象中不论什么一个非静态的成员或非静态的成员函数。不能去获得他们的地址,或者进行其它的操作。
4.堆:堆是还有一种动态内存区域,它是通过malloc()/free()函数以及这些函数的其它形式来进行分配/释放的。
我们要注意的是,虽然在某个特定的编译器中,默认的全局运算符new和delete可能会用函数malloc()和free()来进行实现,可是堆还是不同于自由存储。在堆中分配的内存不能再自由存储区域中被安全地释放,反之亦然 在堆中分配的内存。能够用于对象的placement new构造过程 和显示的析构过程中。假设是这样的使用方法。那么自由存储区域中关于对象生存期的注意事项也相同适用于堆。
5.全局/静态:在程序启动的时候,这些变量/对象或静态的变量/对象就已经被分配了存储空间,但仅仅有等到程序运行的时候,这些变量/对象才干够进行初始化。
比如:函数中的静态变量仅仅有当程序第一次运行到变量的定义语句时才干被初始化。
对于跨越多个编译单元的全局变量,它们的初始化顺序是未定义的。而且我们在管理全局对象(包含类的静态成员)之间的依赖性的时候要特别小心。通常来说,我们能够通过一个void*指针来对未初始化的对象存储空间进行訪问和操作,但我们不能再对象的生存期之外来使用或者引用非静态的成员变量或成员函数。
指导原则:我们应该优先使用自有存储(new/delete),而且要避免去使用堆(malloc/free)。
C++中的内存区域及其性能特征的更多相关文章
- Java虚拟机中Java内存区域
Java虚拟机所管理的内存将会包括以下几个运行时数据区域. 程序计数器 可以看作是当前线程所执行的字节码的行号指示器. 每一个线程都需要有一个独立的程序计数器. 如果线程正在执行的是一个Java方 ...
- 用 Span 对 C# 进程中三大内存区域进行统一访问 ,太厉害了!
一:背景 1. 讲故事 前段时间写了几篇 C# 漫文,评论留言中有很多朋友多次提到 Span,周末抽空看了下,确实是一个非常
- JVM性能优化系列-(1) Java内存区域
1. Java内存区域 1.1 运行时数据区 Java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干个不同的数据区域.主要包括:程序计数器.虚拟机栈.本地方法栈.Java堆.方法区(运 ...
- jvm的内存区域介绍
什么是jvm? JVM是Java Virtual Machine(Java虚拟机)的缩写,JVM是一种用于计算设备的规范,它是一个虚构出来的计算机,是通过在实际的计算机上仿真模拟各种计算机功能来实现的 ...
- JVM的内存区域划分以及垃圾回收机制详解
在我们写Java代码时,大部分情况下是不用关心你New的对象是否被释放掉,或者什么时候被释放掉.因为JVM中有垃圾自动回收机制.在之前的博客中我们聊过Objective-C中的MRC(手动引用计数)以 ...
- 深入了解java虚拟机(JVM) 第三章 内存区域----堆空间
一.堆的含义 jvm堆的区域主要是用来存放对象的实例,它的空间大小是JVM内存区域中占比重最大的,也是jvm最大的内存管理模块,最重要的是,这个区域是垃圾收集器主要管理的区域,这意味着我们在考虑垃圾回 ...
- Linux内存都去哪了:(1)分析memblock在启动过程中对内存的影响
关键词:memblock.totalram_pages.meminfo.MemTotal.CMA等. 最近在做低成本方案,需要研究一整块RAM都用在哪里了? 最直观的的就是通过/proc/meminf ...
- [Spark性能调优] 第四章 : Spark Shuffle 中 JVM 内存使用及配置内幕详情
本课主题 JVM 內存使用架构剖析 Spark 1.6.x 和 Spark 2.x 的 JVM 剖析 Spark 1.6.x 以前 on Yarn 计算内存使用案例 Spark Unified Mem ...
- C/C++中内存区域划分大总结
C++作为一款C语言的升级版本,具有非常强大的功能.它不但能够支持各种程序设计风格,而且还具有C语言的所有功能.我们在这里为大家介绍的是其中一个比较重要的内容,C和C++内存区域的划分. 一. 在c中 ...
随机推荐
- How to set asp.net Identity cookies expires time
If IsPersistent property of AuthenticationProperties is set to false, then the cookie expiration tim ...
- [JS] ECMAScript 6 - Class : compare with c#
Ref: Class 的基本语法 Ref: Class 的基本继承 许多面向对象的语言都有修饰器(Decorator)函数,用来修改类的行为.目前,有一个提案将这项功能,引入了 ECMAScript. ...
- 网络编程 -- RPC实现原理 -- RPC -- 迭代版本V3 -- 远程方法调用 整合 Spring
网络编程 -- RPC实现原理 -- 目录 啦啦啦 V3——RPC -- 远程方法调用 及 null的传输 + Spring 服务提供商: 1. 配置 rpc03_server.xml 注入 服务提供 ...
- 嵌入式Linux应用开发__求职要求
A.熟悉嵌入式软件开发,有较好的C语言开发能力,熟悉Linux线程,信号量,同步,消息队列,网络编程,音频等:B.能够熟练使用GDB调试工具:C.熟悉linux脚本,对于Android编译环境有一定理 ...
- redis最大缓存和回收策略
- spark基础---->spark的第一个程序
这里面我们介绍一下spark的安装,并通过一个python的例子来简单的体会一下spark的使用. spark的安装与使用 安装环境:mac 10.13.6,spark版本:2.3.1,python版 ...
- 获取HttpServletRequest请求Body中的内容
在实际开发过程中,经常需要从 HttpServletRequest 中读取HTTP请求的body内容,俗话说的好”好记性不如烂笔头“,特在此将其读取方法记录一下. import java.io.Buf ...
- 解决UEFI启动模式下无法使用U盘启动WIN7安装界面
问题场景 现在很多人都习惯使用U盘进行安装系统,主要是快捷方便.本文主要是讲解一下U盘在UEFI模式下无法启动Windows7安装界面的问题,可能很多人会说使用PE系统进行安装,但是因为我的主板只有独 ...
- C# 反射(Reflection)
什么是反射 发射是 .net framework 提供的一个帮助类库,用于读取和使用元数据. 用到的类:System.Reflection,System.Type.System.Type 类对于反射起 ...
- vmware的centos 6虚拟机如何共享文件夹?
1.点 虚拟机-设置 2. 点击 选项-共享文件夹: 3.点击添加,选择 windows主机的一个文件夹作为 共享文件夹: 5.点击完成-确定以后,重启虚拟机(客户机),在虚拟机中: 点击 compu ...