C ++ 동적 메모리

C ++에서 동적 메모리가 실제로 어떻게 작동하는지 잘 이해하는 것은 훌륭한 C ++ 프로그래머가되기 위해 필수적입니다. C ++ 프로그램의 메모리는 두 부분으로 나뉩니다.

  • The stack − 함수 내에서 선언 된 모든 변수는 스택에서 메모리를 차지합니다.

  • The heap − 이것은 프로그램의 미사용 메모리이며 프로그램 실행시 동적으로 메모리를 할당하는 데 사용할 수 있습니다.

정의 된 변수에 특정 정보를 저장하는 데 필요한 메모리 양을 미리 알지 못하며 필요한 메모리의 크기는 런타임에 결정할 수 있습니다.

할당 된 공간의 주소를 반환하는 C ++의 특수 연산자를 사용하여 주어진 유형의 변수에 대한 힙 내에서 런타임에 메모리를 할당 할 수 있습니다. 이 연산자는new 운영자.

더 이상 동적으로 할당 된 메모리가 필요하지 않은 경우 다음을 사용할 수 있습니다. delete 연산자는 이전에 new 연산자에 의해 할당 된 메모리를 할당 해제합니다.

신규 및 삭제 연산자

사용할 일반 구문은 다음과 같습니다. new 연산자는 모든 데이터 유형에 대해 동적으로 메모리를 할당합니다.

new data-type;

여기, data-type배열을 포함하는 내장 데이터 유형이거나 사용자 정의 데이터 유형에 클래스 또는 구조가 포함될 수 있습니다. 내장 데이터 유형부터 시작하겠습니다. 예를 들어 double 유형에 대한 포인터를 정의한 다음 실행 시간에 메모리가 할당되도록 요청할 수 있습니다. 우리는new 다음 문과 연산자-

double* pvalue  = NULL; // Pointer initialized with null
pvalue  = new double;   // Request memory for the variable

사용 가능한 저장소가 모두 사용 된 경우 메모리가 성공적으로 할당되지 않았을 수 있습니다. 따라서 new 연산자가 NULL 포인터를 반환하는지 확인하고 아래와 같이 적절한 조치를 취하는 것이 좋습니다.

double* pvalue  = NULL;
if( !(pvalue  = new double )) {
   cout << "Error: out of memory." <<endl;
   exit(1);
}

그만큼 malloc()C의 함수는 여전히 C ++에 존재하지만 malloc () 함수를 사용하지 않는 것이 좋습니다. malloc ()에 비해 new의 가장 큰 장점은 new가 메모리를 할당하는 것이 아니라 C ++의 주요 목적인 객체를 생성한다는 것입니다.

언제든지 동적으로 할당 된 변수가 더 이상 필요하지 않다고 생각되면 다음과 같이 'delete'연산자를 사용하여 free store에서 차지하는 메모리를 비울 수 있습니다.

delete pvalue;        // Release memory pointed to by pvalue

위의 개념을 입력하고 '새로 만들기'와 '삭제'가 작동하는 방식을 보여주기 위해 다음 예제를 구성 해 보겠습니다.

#include <iostream>
using namespace std;

int main () {
   double* pvalue  = NULL; // Pointer initialized with null
   pvalue  = new double;   // Request memory for the variable
 
   *pvalue = 29494.99;     // Store value at allocated address
   cout << "Value of pvalue : " << *pvalue << endl;

   delete pvalue;         // free up the memory.

   return 0;
}

위의 코드를 컴파일하고 실행하면 다음 결과가 생성됩니다.

Value of pvalue : 29495

어레이에 대한 동적 메모리 할당

문자 배열, 즉 20 자 문자열에 메모리를 할당하려는 경우를 고려하십시오. 위에서 사용한 것과 동일한 구문을 사용하여 아래와 같이 동적으로 메모리를 할당 할 수 있습니다.

char* pvalue  = NULL;         // Pointer initialized with null
pvalue  = new char[20];       // Request memory for the variable

방금 생성 한 배열을 제거하려면 다음과 같은 구문을 사용합니다.

delete [] pvalue;             // Delete array pointed to by pvalue

new 연산자의 유사한 일반 구문에 따라 다음과 같이 다차원 배열에 할당 할 수 있습니다.

double** pvalue  = NULL;      // Pointer initialized with null 
pvalue  = new double [3][4];  // Allocate memory for a 3x4 array

그러나 다차원 배열에 대한 메모리를 해제하는 구문은 여전히 ​​위와 동일합니다.

delete [] pvalue;            // Delete array pointed to by pvalue

개체에 대한 동적 메모리 할당

객체는 단순한 데이터 유형과 다르지 않습니다. 예를 들어, 개념을 명확히하기 위해 객체 배열을 사용할 다음 코드를 고려하십시오.

#include <iostream>
using namespace std;

class Box {
   public:
      Box() { 
         cout << "Constructor called!" <<endl; 
      }
      ~Box() { 
         cout << "Destructor called!" <<endl; 
      }
};
int main() {
   Box* myBoxArray = new Box[4];
   delete [] myBoxArray; // Delete array

   return 0;
}

네 개의 Box 객체 배열을 할당하면 Simple 생성자가 네 번 호출되고 이러한 객체를 삭제하는 동안 유사하게 소멸자가 동일한 횟수로 호출됩니다.

위의 코드를 컴파일하고 실행하면 다음 결과가 생성됩니다.

Constructor called!
Constructor called!
Constructor called!
Constructor called!
Destructor called!
Destructor called!
Destructor called!
Destructor called!