* Placement New
표준 C++에서 제공하는 기능으로,
새롭게 메모리에 할당하지 않고, 사용자가 제공한 특정 메모리 위치에 객체를 생성한다
#include <iostream>
class CTest
{
public:
CTest()
{
printf("CTest Constructor\n");
}
~CTest()
{
printf("CTest Destructor\n");
}
int _x = 1;
int _y = 1;
};
int main(void)
{
// 일반 동적 할당
//CTest* p1 = new CTest();
//delete p1;
// placement new 예제
char buffer[sizeof(CTest)]; // 충분한 크기의 버퍼를 생성
CTest* p2 = new (buffer) CTest(); // buffer 위치에 객체 생성
// 수동으로 소멸자를 호출해야 함
p2->~CTest();
// 동적할당이 아니기 때문에 free할 필요 없음
return 0;
}
(+) 만약 메모리를 malloc을 통해 동적으로 할당했다면, free를 호출해야 한다
void* buffer = std::malloc(sizeof(CTest));
CTest* p2 = new (buffer) CTest();
p2->~CTest();
std::free(buffer); // 동적 할당된 메모리 해제
아래의 정리 내용은 Placement New가 스택 메모리나 미리 확보된 메모리를 사용하는 경우를 전제로 작성되었다
힙 메모리를 사용하는 동적 할당의 경우 일부 내용이 해당되지 않을 수 있다
* 특징
1. 기존 메모리를 재사용
new 연산자를 사용해 메모리를 동적으로 할당하는 대신, 사용자가 제공한 메모리에서 객체를 생성한다
2. 소멸자 호출 필요
Placement New로 생성한 객체를 자동으로 소멸되지 않는다
따라서, 명시적으로 소멸자를 호출해야 한다
3. 힙 메모리 사용 없음
메모리 할당 비용이 발생하지 않으므로, 성능을 최적화할 때 유용하다
* 메모리 풀(Memory Pool)이나 커스텀 메모리 관리를 구현할 때 자주 사용된다
* 메모리 풀에 사용했을 때의 장점
1. 성능 최적화
동적 할당보다 빠르게 메모리를 재활용할 수 있다
2. 메모리 단편화 방지
메모리 풀은 고정된 크기의 블록으로 단편화 문제를 줄일 수 있다
3. 예측 가능한 동작
메모리 풀이 미리 할당된 메모리를 사용하므로, 메모리 사용 패턴을 예측 가능하게 만든다
* 실제 사용 사례
1. 게임 서버 개발
많은 객체가 반복적으로 생성 및 소멸되는 경우(예: 몬스터, 총알 등)
2. 네트워크 프로그래밍
패킷 처리와 같은 고빈도 작업
3. 실시간 시스템
일정한 성능을 보장해야하는 시스템
* DB Connection Pool과 Memory Pool은 개념적으로 비슷
* 참고
1. https://yuu5666.tistory.com/41
2. https://velog.io/@dnjfs/C-%EC%A4%91%EA%B8%89-Placement-New
3. https://woo-dev.tistory.com/217
4. ChatGPT
'IT공부' 카테고리의 다른 글
[C++] 접근 제어자 private 자바와의 차이점 (0) | 2024.12.29 |
---|---|
[ETC] 레드 블랙 트리 (0) | 2024.12.19 |
[ETC] 커널 전역 데이터 구조, 전역 or 프로세스별 커널 오브젝트 (0) | 2024.12.14 |
[ETC] 지수와 로그 역관계 (0) | 2024.12.14 |
[ETC] 꼭 알아야 하는 어셈블리 명령어 (0) | 2024.12.05 |