C++ 内存分区模型的使用(代码区、全局区、栈区、堆区、new)

内存分区模型

1 代码区

2 全局区

// 全局变量、静态变量、常量

#include <iostream>
using namespace std;

// 全局变量、静态变量、常量

//全局变量
int g_a=10;
int g_b=10;

//const修饰的全局常量
const int c_g_a = 10;
const int c_g_b = 10;

int main()
{
	//创建普通局部变量
	int a = 10;
	int b = 10;
	cout << "局部变量a的地址为:" << (int)&a << endl;//&a取地址,(int)强制转换为10进制
	cout << "局部变量b的地址为:" << (int)&b <<endl<<endl;

	//全局变量
	cout << "全局变量g_a的地址为:" << (int)&g_a << endl;
	cout << "全局变量g_b的地址为:" << (int)&g_b << endl<<endl;

	//静态变量
	static int s_a = 10;
	static int s_b = 10;
	cout << "静态变量s_a的地址为:" << (int)&s_a << endl;
	cout << "静态变量s_b的地址为:" << (int)&s_b << endl << endl;

	//常量(字符串常量、const修饰的变量)
	//字符串常量
	cout << "字符串常量的地址为:" << (int)&"hello word" << endl;

	//const修饰的变量(全局常量、局部常量)
	//const修饰的全局变量
	cout << "全局常量 c_g_a的地址为:" << (int)&c_g_a << endl;
	cout << "全局常量 c_g_b的地址为:" << (int)&c_g_b << endl;

	//const修饰的局部变量
	const int c_a = 10;
	const int c_b = 10;
	cout << "局部常量 c_a的地址为:" << (int)&c_a << endl;
	cout << "局部常量 c_b的地址为:" << (int)&c_b << endl << endl;

	system("pause");
	return 0;
}

总结

3 栈区

栈区注意事项

  • 不要返回局部变量的地址
  • 栈区的数据由编译器管理开辟和释放
#include <iostream>
using namespace std;

//栈区注意事项
//不要返回局部变量的地址
//栈区的数据由编译器管理开辟和释放

int *func(int b)//形参数据也存放在栈区
{
	b = 100;
	int a = 10;//局部变量:存放在栈区,栈区的数据在函数执行完毕自动释放
	return &a;//返回局部变量的地址
}
int main()
{
	//接受func函数的返回值
	int *p=func(1);
	cout << *p << endl;//第一次可以打印正确的数字,因为编译做了一次保留
	cout << *p << endl;//第二次,就没了,输出乱码

	system("pause");
	return 0;
}

4 堆区

#include <iostream>
using namespace std;
int *func()
{
	//利用new关键字,将数据开辟到堆区
	//指针本质也是局部变量,存放在栈上,指针保存的数据存放咋堆区
	int* p = new int(10);
	return p;
}
int main()
{
	//在堆区开辟数据
	int* q = func();
	cout << *q << endl;//与上一个程序对比,多输出几次
	cout << *q << endl;
	cout << *q << endl;
	cout << *q << endl;

	system("pause");
	return 0;
}

5 new运算符

#include <iostream>
using namespace std;

//1.new的基本语法
int* func()
{
	//在堆区创建整形数据
	//new返回的是数据类型指针
	int* p = new int(10);
	return p;
}
//2.在堆区利用new 开辟数组
int main()
{
	//在堆区开辟数据
	int* q = func();
	cout << *q << endl;//与上一个程序对比,多输出几次
	cout << *q << endl;
	cout << *q << endl;

	//堆区数据是由程序员管理开辟、管理释放
	//如果想释放堆区数据,利用关键字delete
	delete q;
	cout << *q << endl;//内存已被释放,再次访问就是非法操作,报错

	system("pause");
	return 0;
}

#include <iostream>
using namespace std;

//1.new的基本语法

//2.在堆区利用new 开辟数组
void test()
{
	//创建10整形数据的数组,在堆区
	int *arr =new int[10];//10代表数组有10个元素

	for (int i = 0; i < 10; i++)
	{
		arr[i] = i + 100;//给10个元素赋值,100~109
	}
	for (int i = 0; i < 10; i++)
		cout << arr[i] << endl;

	//释放堆取数组
	//释放数组的时候,要加[]才可以,否则认为是只是放一个元素
	delete[] arr;
}
int main()
{
	test();
	system("pause");
	return 0;
}

注意:

  • 释放堆取数组
  • 释放数组的时候,要加[]才可以,否则认为是只是放一个元素

参考:
哔哩哔哩 黑马程序员

到此这篇关于C++ 内存分区模型的使用(代码区、全局区、栈区、堆区、new)的文章就介绍到这了,更多相关C++ 内存分区模型内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • C++中的内存分区介绍

    C++的内存划分为栈区.堆区.全局区/静态区.字符串常量和代码区. 这里去掉自由存储区,增加了代码区,理由会在下面讲到. 栈区:由系统进行内存的管理. 说明:主要存放函数的参数以及局部变量.栈区由系统进行内存管理,在函数完成执行,系统自行释放栈区内存,不需要用户管理.整个程序的栈区的大小可以在编译器中由用户自行设定,默认的栈区大小为3M. 全局/静态区:全局.静态数据存放在一起的,初始化的全局变量和静态变量是在一起的.未初始化的全局变量和静态变量是在相邻的空间中. 说明:全局变量和静态全局变量的

  • C++ 内存分区模型的使用(代码区、全局区、栈区、堆区、new)

    内存分区模型 1 代码区 2 全局区 // 全局变量.静态变量.常量 #include <iostream> using namespace std; // 全局变量.静态变量.常量 //全局变量 int g_a=10; int g_b=10; //const修饰的全局常量 const int c_g_a = 10; const int c_g_b = 10; int main() { //创建普通局部变量 int a = 10; int b = 10; cout << "

  • 详解C++内存的代码区,全局区,栈区和堆区

    目录 代码区: 全局区: 栈区 堆区 总结 今天无意中刷到了一篇关于c++内存的帖子,我发现那个人好像写的不太对,然后同时我自己也发现我对一块还不够了解,所以我干脆就自己去了解整理了一下:首先我们要大概知道四个区都是干什么的 代码区: 顾名思义,就是存放我们写的代码的地方,不过要注意的是存放的是二进制代码. 注意:我们写的所有的写的代码(包括注释.变量.语句等)都会放到代码区中. 全局区: 存放全局,静态变量以及常量. 注意: 1.全局区里有一个部分叫常量区,储存的是常量,如const修饰的全局

  • C++核心编程之内存分区详解

    目录 1.内存分区模型: 2.代码区: 3.全局区: 4.小结: 5.代码演示: 6.运行结果: 总结 1.内存分区模型: C++程序在执行时,将内存大方向划分成4个区域 (1)代码区:存放安徽念书体的二进制代码,由操作系统进行管理的 (2)全局区:存放全局变量和静态变量以及常量 (3)栈区:由编译器自动分配释放,存放函数的参数值,局部变量等 (4)堆区:由程序员分配和释放,若程序员不释放,程序结束时由操作系统回收 内存四区意义:不同区域存放的数据,赋予不同的生命周期,给我们更大的灵活编程 2.

  • C++程序内存栈区与堆区模型案例分析

    目录 栈区: 栈区代码演示: 堆区: 堆区代码演示: new操作符: new操作符代码演示: 栈区: 由编译器自动分配释放,存放函数的参数值,局部变量等(由编译器管理其“生死”) 注意事项:不要返回局部变量的地址,栈区开辟的数据由编译器自动释放 栈区代码演示: //内存四区-栈区 /* 栈区: 由编译器自动分配释放,存放函数的参数值,局部变量等(由编译器管理其"生死") 注意事项:不要返回局部变量的地址,栈区开辟的数据由编译器自动释放 */ #include <iostream&

  • C++内存四区之代码区、全局区、栈区和堆区

    C++内存四区 C++ 在程序执行时,将内存大致分为代码区,全局区,栈区和堆区四个区域.不同的区域存储不同的数据,赋予不同的生命周期,能够更灵活地进行编程. 代码区:存放函数体的二进制代码,由操作系统管理创建,代码区时共享的,对于频繁被执行的程序,只需要存有一份代码即可: 全局区:存放全局变量和静态变量以及常量,在程序结束后由操作系统释放: 栈区:由编译其自动分配释放,存放函数的参数值以及局部变量等: 堆区:一般由程序员通过 new 开辟空间,进行分配和释放,若程序员不释放,则程序结束时由操作系

  • 一篇文章总结Java虚拟机内存区域模型

    首先我们来看一下Java运行时的数据区域,Java虚拟机在执行Java程序的过程中会把它所管理的内存划分成若干个不同的数据区域,这些区域都有各自的用途,各自的创建和销毁的时间.有的区域随着虚拟机进程的启动而存在,有些区域则依赖用户线程的启动和结束而建立和销毁. 我们来看一下Java虚拟机运行时的数据区 结合这张图,下面逐个来分析一下每个数据区域的特点. 1.程序计数器 程序计数器是一块较小的内存空间,可以看作是当前线程所执行的字节码的行号指示器. 什么意思呢?我们知道,CPU的计算时间是以分片的

  • C++ 面向对象程序设计--内存分区详解

    目录 一.分区的意义 二.代码区 1.定义 2.特点 三.全局区 1.定义 2.特点 3.相关代码 1)全局变量 2)静态变量 四.栈区--程序运行后 1.定义 2.相关代码 五.堆区--运行后 1.定义 2.相关代码和运行结果 总结 一.分区的意义 在讲分区前,先谈谈内存分区的意义,也就是为什么程序要进行分区? 笔者认为这是为了编程的灵活性,因为将内存分区后,不同区域的内存,相关的数据就有的不同的生命周期.以笔者之前的一篇算法复杂度的blog中提到栈帧空间为例,在此就是指栈区,而栈区多指非ma

  • C++程序的五大内存分区实力详解

    目录 1.栈内存区 1.1.调用函数时通过栈来传递函数的参数值 1.2.线程占用的栈内存是有上限的 2.堆内存区 3.全局/静态内存区 4.文字常量区 5.程序代码区 总结 C++程序在运行时所占用的内存区域,一般可分为栈内存区.堆内存区.全局/静态内存区.文字常量内存区及程序代码区5大分区: 下面使用日常开发中的编程实例,详细介绍一下这5个分区,以便大家能更深刻的理解这5大内存分区. 1.栈内存区 栈内存区是我们用的最多的分区,只要有函数的地方都会使用到这个分区.栈分区是用来存放函数参数及函数

  • C++程序的五大内存分区实例详解

    目录 1.栈内存区 1.1.调用函数时通过栈来传递函数的参数值 1.2.线程占用的栈内存是有上限的 2.堆内存区 3.全局/静态内存区 4.文字常量区 5.程序代码区 C++程序在运行时所占用的内存区域,一般可分为栈内存区.堆内存区.全局/静态内存区.文字常量内存区及程序代码区5大分区: 下面使用日常开发中的编程实例,详细介绍一下这5个分区,以便大家能更深刻的理解这5大内存分区. 1.栈内存区 栈内存区是我们用的最多的分区,只要有函数的地方都会使用到这个分区.栈分区是用来存放函数参数及函数局部变

  • 浅析栈区和堆区内存分配的区别

    一直以来总是对这个问题的认识比较朦胧,我相信很多朋友也是这样的,总是听到内存一会在栈上分配,一会又在堆上分配,那么它们之间到底是怎么的区别呢?为了说明这个问题,我们先来看一下内存内部的组织情况. 从上图可知,程序占用的内存被分了以下几部分. 1.栈区(stack)由编译器自动分配释放 ,存放函数的参数值,局部变量的值等,内存的分配是连续的,类似于平时我们所说的栈,如果还不清楚,那么就把它想成数组,它的内存分配是连续分配的,即,所分配的内存是在一块连续的内存区域内.当我们声明变量时,那么编译器会自

随机推荐