C++ 동적 메모리
C++에서 동적 메모리가 작동하는 방식을 이해하는 것은 자격을 갖춘 C++ 프로그래머가 되는 데 필수적입니다. C++ 프로그램의 메모리는 두 부분으로 나뉩니다.
스택: 함수 내부에 선언된 모든 변수는 스택 메모리를 차지합니다.
힙: 프로그램에서 사용되지 않은 메모리이며 프로그램이 실행되는 동안 동적으로 메모리를 할당하는 데 사용할 수 있습니다.
정의된 변수에 특정 정보를 저장하는 데 필요한 메모리 양을 미리 예측할 수 없는 경우가 많습니다. 필요한 메모리 크기는 런타임에 결정되어야 합니다.
C++에서는 할당된 공간의 주소를 반환하는 특수 연산자를 사용하여 특정 유형의 변수에 대해 런타임 시 힙에 메모리를 할당할 수 있습니다. 이 연산자는 new 연산자입니다.
동적으로 메모리를 할당할 필요가 없다면 delete 연산자를 사용하여 이전에 new 연산자가 할당한 메모리를 삭제할 수 있습니다.
new 및 delete 연산자
다음은 new 연산자를 사용하여 모든 데이터 유형에 대해 메모리를 동적으로 할당하기 위한 일반적인 구문입니다.
new data-type;
여기에서 data-type은 배열을 포함한 모든 내장 데이터일 수 있습니다. 유형도 가능합니다. 클래스나 구조를 포함한 사용자 정의 데이터 유형이어야 합니다. 먼저 내장 데이터 유형을 살펴보겠습니다. 예를 들어, double 유형에 대한 포인터를 정의한 다음 실행 시 할당되는 메모리를 요청할 수 있습니다. 다음과 같이 new 연산자를 사용하여 이를 수행할 수 있습니다.
double* pvalue = NULL; // 初始化为 null 的指针 pvalue = new double; // 为变量请求内存
여유 저장 공간이 모두 소진된 경우 메모리 할당이 성공하지 못할 수 있습니다. 따라서 new 연산자가 NULL 포인터를 반환하는지 확인하고 다음과 같은 적절한 조치를 취하는 것이 좋습니다.
double* pvalue = NULL; if( !(pvalue = new double )) { cout << "Error: out of memory." <<endl; exit(1); }
malloc() 이 함수는 C 언어에서 나타났고 여전히 C++에도 존재하지만, 수행하지 않는 것이 좋습니다. 가능한 한 malloc() 함수를 사용하십시오. malloc() 함수와 비교하여 new의 주요 장점은 new가 메모리를 할당할 뿐만 아니라 객체도 생성한다는 것입니다.
동적으로 메모리가 할당된 변수가 더 이상 필요하지 않다고 생각되면 언제든지 아래와 같이 삭제 연산자를 사용하여 해당 변수가 차지하는 메모리를 해제할 수 있습니다.
delete pvalue; // 释放 pvalue 所指向的内存
위 내용은 다음에서 사용됩니다. new 및 delete 연산자를 사용하는 방법을 보여주는 예제 개념:
#include <iostream> using namespace std; int main () { double* pvalue = NULL; // 初始化为 null 的指针 pvalue = new double; // 为变量请求内存 *pvalue = 29494.99; // 在分配的地址存储值 cout << "Value of pvalue : " << *pvalue << endl; delete pvalue; // 释放内存 return 0; }
위 코드를 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.
Value of pvalue : 29495
배열의 동적 메모리 할당
문자 배열( 20자 문자열) 메모리를 할당하려면 위 예제의 구문을 사용하여 다음과 같이 배열에 대한 메모리를 동적으로 할당할 수 있습니다.
char* pvalue = NULL; // 初始化为 null 的指针 pvalue = new char[20]; // 为变量请求内存
방금 생성한 배열을 삭제하려면 명령문은 다음과 같습니다.
delete [] pvalue; // 删除 pvalue 所指向的数组
아래는 다차원 배열에 메모리를 할당할 수 있는 new 연산자의 일반적인 구문입니다.
int ROW = 2; int COL = 3; double **pvalue = new double* [ROW]; // 为行分配内存 // 为列分配内存 for(int i = 0; i < COL; i++) { pvalue[i] = new double[COL]; }
다차원 배열 메모리 해제:
for(int i = 0; i < COL; i++) { delete[] pvalue[i]; } delete [] pvalue;
객체의 동적 메모리 할당
객체는 단순 데이터와 다르지 않습니다. 유형. 예를 들어, 이 개념을 명확히 하기 위해 객체 배열을 사용하는 아래 코드를 살펴보세요.
#include <iostream> using namespace std; class Box { public: Box() { cout << "调用构造函数!" <<endl; } ~Box() { cout << "调用析构函数!" <<endl; } }; int main( ) { Box* myBoxArray = new Box[4]; delete [] myBoxArray; // Delete array return 0; }
4개의 Box 객체가 포함된 배열에 메모리를 할당하려는 경우 생성자는 4번 호출됩니다. 마찬가지로 객체가 삭제되면 소멸자도 동일한 횟수(4번) 호출됩니다.
위 코드를 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.
调用构造函数! 调用构造函数! 调用构造函数! 调用构造函数! 调用析构函数! 调用析构函数! 调用析构函数! 调用析构函数!