[Ядро C++] Анализ модели раздела памяти C++

При выполнении программы C++ общее направление памяти делится на 4 области.

  • Кодовая область : хранилище 函数体的二进制代码, управляемое операционной системой
  • Глобальная область : хранит суммы 全局变量и 静态变量константы
  • Область стека : автоматически выделяется и освобождается компилятором,存放函数的参数值,局部变量等
  • Область кучи : 由程序员分配和释放если программист не освободит ее, она будет освобождена операционной системой в конце программы.

Значение четырех областей памяти: данные, хранящиеся в разных областях, наделены разным жизненным циклом, что дает нам большую гибкость в программировании

1. Перед запуском программы

После компиляции программы генерируется исполняемая программа, которая делится на две области перед выполнением программы.

Храните代码区: машинные инструкции, выполняемые ЦП,

1. Область кода является общей .Цель совместного использования заключается в том, что для часто исполняемых программ в памяти должна находиться только одна копия кода.
2. Область кода доступна только для чтения .Причина для того, чтобы сделать его доступным только для чтения, состоит в том, чтобы предотвратить случайное изменение программой своих инструкций.

全局区:Здесь хранятся глобальные

Глобальная область также содержит область констант, где хранятся строковые константы и другие константы.Данные в этой области освобождаются операционной системой после завершения программы..

Пример:

#include<iostream>
using namespace std;

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

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

int main() {
    
    

	//局部变量
	int a = 10;
	int b = 10;

	//打印地址
	cout << "局部变量a地址为: " << &a << endl;
	cout << "局部变量b地址为: " << &b << endl;

	cout << "全局变量g_a地址为: " <<  &g_a << endl;
	cout << "全局变量g_b地址为: " <<  &g_b << endl;

	//静态变量
	static int s_a = 10;
	static int s_b = 10;

	cout << "静态变量s_a地址为: " << &s_a << endl;
	cout << "静态变量s_b地址为: " << &s_b << endl;

	cout << "字符串常量地址为: " << &"hello world" << endl;
	cout << "字符串常量地址为: " << &"hello world1" << endl;

	cout << "全局常量c_g_a地址为: " << &c_g_a << endl;
	cout << "全局常量c_g_b地址为: " << &c_g_b << endl;

	const int c_l_a = 10;
	const int c_l_b = 10;
	cout << "局部常量c_l_a地址为: " << &c_l_a << endl;
	cout << "局部常量c_l_b地址为: " << &c_l_b << endl;

	return 0;
}

Результат выполнения:

局部变量a地址为: 0x309764408
局部变量b地址为: 0x309764404
全局变量g_a地址为: 0x1029720c0
全局变量g_b地址为: 0x1029720c4
静态变量s_a地址为: 0x1029720c8
静态变量s_b地址为: 0x1029720cc
字符串常量地址为: 0x10296deb7
字符串常量地址为: 0x10296dec3
全局常量c_g_a地址为: 0x10296df4c
全局常量c_g_b地址为: 0x10296df50
局部常量c_l_a地址为: 0x309764400
局部常量c_l_b地址为: 0x3097643fc

Подведем итог:

  • C++ делится на глобальную область и область кода перед запуском программы.
  • Область кода характеризуется разделяемыми и доступными только для чтения
  • Храните глобальные переменные, статические переменные и константы в глобальной области
  • Храните измененные константы глобальные константы и строковые константы в области констант

2. После запуска программы

栈区:Автоматически выделяется и освобождается компилятором

Примечание. Не возвращайте адрес локальной переменной, данные, созданные в области стека, будут автоматически освобождены компилятором.

Пример:

#include<iostream>
using namespace std;

int * func()
{
    
    
	int a = 10;
	return &a;
}

int main() {
    
    

	int *p = func();

	cout << *p << endl;
	cout << *p << endl;

	return 0;
}

堆区:Он выделяется и освобождается программистомВ C++ new в основном используется для открытия памяти в области кучи.

Пример:

#include<iostream>
using namespace std;

int* func()
{
    
    
	int* a = new int(10);
	return a;
}

int main() {
    
    
	int *p = func();

	cout << *p << endl;
	cout << *p << endl;
	
	return 0;
}

Подведем итог:

  • Данные области кучи управляются и выпускаются программистом.
  • Данные области кучи используют новое ключевое слово для открытия памяти.

3. Новый оператор

Использование в С++новыйОператор разрабатывает данные в области кучи, а данные, разработанные в области кучи, вручную разрабатываются программистом и выпускаются вручную, а в выпуске используется операторудалить

Грамматика: new 数据类型

Данные, созданные new, вернут указатель типа, соответствующего данным.

Случай 1: Базовая грамматика

#include<iostream>
using namespace std;

int* func()
{
    
    
	int* a = new int(10);
	return a;
}

int main() {
    
    
	int *p = func();

	cout << *p << endl;
	cout << *p << endl;

	//利用delete释放堆区数据
	delete p;

	//cout << *p << endl; //报错,释放的空间不可访问

	return 0;
}

Случай 2: открыть массив

#include<iostream>
using namespace std;

//堆区开辟数组
int main() {
    
    

	int* arr = new int[10];

	for (int i = 0; i < 10; i++)
	{
    
    
		arr[i] = i + 100;
	}

	for (int i = 0; i < 10; i++)
	{
    
    
		cout << arr[i] << endl;
	}
	//释放数组 delete 后加 []
	delete[] arr;

	return 0;
}

Supongo que te gusta

Origin blog.csdn.net/cui_yonghua/article/details/131343153
Recomendado
Clasificación