Simplified Memory Modle C/C++内存模型

  最近学习c++看视频时,老师时常提到栈区堆区,搞不清楚,只能泪目,毕竟爱过。。。因此,接下来对此做些整理,方便回顾。(老师说:这个简化模型仅用于初学者示意,与实际模型并不完全一致)

1.stack(栈)

  编译器自动分配释放

2.Heap(堆)

  一般由程序员分配释放,若程序员不释放,程序结束时可能由OS回收

3.Global/Static(全局区/静态区)

  全局变量和静态变量的存储是放在一块的

  可以简单认为:

    程序启动全局/静态变量就在此处

    程序结束释放

4.Constant(常量区)

  可以简单理解为所有常量都放在一起

  该区域内容不可修改

堆向高地址方向生长   栈向地地址方向生长

Eg1.

int arr[3];    //全局区

int myFunc( int * pi)

{

  int a;    

  char *p;

  p = static_cast<char*> new char[8];

  char* str = "hello world";

}

//pi a p str --->栈区

//char[8](new出来的) --->堆区

//"hello world"--->常量区

时间: 2024-10-27 02:30:20

Simplified Memory Modle C/C++内存模型的相关文章

java内存模型与线程(转) good

java内存模型与线程 参考 http://baike.baidu.com/view/8657411.htm http://developer.51cto.com/art/201309/410971_all.htm http://www.cnblogs.com/skywang12345/p/3447546.html 计算机的CPU计算能力超强,其计算速度与 内存等存储 和通讯子系统的速度相比快了几个数量级, 数据加载到内存中后,cpu处理器运算处理时,大部分时间花在等待获取去获取磁盘IO.网络通

jvm Java内存模型

硬件的效率与一致性 在计算机中,内存的读写与处理器的计算速度有几个级的差距.这样会严重影响到TPS(Transations Per Second). 所以会为每个处理器配一个高速缓存以缓和处理器的速度.而在计算机中,多个处理器共享一个内存,这个时候数据的读写操作将不会安全 什么是内存模型                                                                        名词解释:JMM(Java Memory Model),即Java内

并发编程学习(一)Java 内存模型

Java 内存模型 什么是 Java 内存模型(Java Memory Model) Java 内存模型是一种规范,规范了 Java 虚拟机和计算机内存是如何进行协同工作的. JMM 规定了一个线程如何和何时看到其它线程修改过后的的共享变量的值,以及在必须时如何同步的访问共享变量. 主内存.高速缓存.寄存器 CPU 包含一系列的寄存器,它们是 CPU 内存的基础. CPU 在寄存器上操作的速度,远大于在主存上读写的速度.是因为 CPU 对寄存器的运行速度远大于主存. 那如何解决这个问题呢?需要引

浅析java内存模型--JMM(Java Memory Model)

在并发编程中,多个线程之间采取什么机制进行通信(信息交换),什么机制进行数据的同步? 在Java语言中,采用的是共享内存模型来实现多线程之间的信息交换和数据同步的. 线程之间通过共享程序公共的状态,通过读-写内存中公共状态的方式来进行隐式的通信.同步指的是程序在控制多个线程之间执行程序的相对顺序的机制,在共享内存模型中,同步是显式的,程序员必须显式指定某个方法/代码块需要在多线程之间互斥执行. 在说Java内存模型之前,我们先说一下Java的内存结构,也就是运行时的数据区域: Java虚拟机在执

C语言内存模型 (C memory layout)

 一. 内存模型                                                                         1. .text 代码区(code section).由编译器链接器生成的可执行指令,程序执行时由加载器(loader)从可执行文件拷贝到内存中.为了安全考虑,防止别的区域更改代码区数据(即可执行指令),代码区具有只读属性.另一个方面,代码区通常具有可共享性(sharable),即在内存中只有一份代码区,如编译器,假如同时有多个编译任务

图解JAVA内存模型(JMM:JAVA Memory Model)

引言 本文主要说明两个问题:JMM存在的意义是什么?JMM内部的工作原理是什么(重点讲一下并发编程模式下的数据访问一致性问题) . 1.为什么要使用JMM? 当我们刚开始接触JAVA语言的时候,就会被告知JAVA程序是可以实现跨平台运行的(即同一份代码资源可运行在不同的硬件配置下,不同的操作系统下).那么JAVA 是如何在不同的硬件和操作系统内存访问方式存在差异的情况下,实现 同一个Java 程序在各种平台下的运行结果都相同(达到一致的内存访问效果)的呢.靠的就是神奇的JMM. 在这里要牢记两个

java内存模型(Java Memory Model)

内容导航: Java内存模型 硬件存储体系结构 Java内存模型和硬件存储体系之间的桥梁: 共享对象的可见性 竞争条件 Java内存模型规定了JVM怎样与计算机存储系统(RAM)协调工作.JVM是一个虚拟机模型,因此这个模型自然包含一个内存的模型 理解java内存模型对于设计正确的并发程序非常重要.JVM规定了不同线程何时以及怎样能看到那些被共享变量的读写,怎样同步对共享变量的訪问控制. 最初的java内存模型并不完好.所以他在java1.5中被改动了.以下的内存模型在java1.8中仍然使用.

并发编程之java内存模型(Java Memory Model ,JMM)

一.图例 0.两个概念 Heap(堆):运行时的数据区,由垃圾回收负责,运行时分配内存(所以慢),对象存放在堆上 如果两个线程,同时调用同一个变量,怎两个线程都拥有,该对象的私有拷贝 (可以看一下,ThreadLocal:   引用注明出处,https://www.cnblogs.com/xiaonantianmen/p/9151481.html) Stack(栈):存放一些引用变量 二.多cpu情况 0.JVM与物理内存之间的通信. 2.线程之间的通信必须通过主内存(此处则是要考虑synchr

The Go Memory Model(go 内存模型)

[译]https://golang.google.cn/ref/mem Go内存模型指定了一个条件,在该条件下,可以保证在一个 goroutine 中读取变量,能够获取到另一个不同 goroutine 写入同一变量产生的值. Introduction Go内存模型指定了一个条件,在该条件下,可以保证在一个 goroutine 中读取变量,能够获取到另一个不同 goroutine 写入同一变量产生的值. Advice 如果一个程序要修改被多个 goroutine 同时访问的数据,必须序列化此类访问