c && c++ 에서 동적으로 할당된 2차원 배열을 해제하는 방법???
글쓴이: wirewalker / 작성시간: 월, 2007/03/19 - 3:23오후
2차원 배열을 보통 다음과 같이 선언합니다.
for i;
int x_num, y_num;
int **matrix;
matrix = (int **)calloc(x_num, size(int **));
for(i=0; i
{
matrix[i] = (int *)calloc(y_num, size(int *));
}
그럼, 할당된 matrix 를 해제할려면, 보통 다음과 같은 방법을 쓰는데,
for(i=0; i
{
free(matrix[i]); <----------------- 1
}
free(matrix);
하지만, 어떤 코드를 보면 다음과 같이 간단한 방법을 쓰더군요...
free(matrix[0]); <------------------
free(matrix);
이렇게 해도 메모리가 제대로 해제 됩니까??
위 코드는 c code지만, c++ 에서는 new[], delete[] 를 위에서처럼 똑같이 사용해서
단 두줄만으로 메모리가 해제가 되는지 궁금합니다.
그리고 된다면, 그 이유를 알고 싶습니다.
글을 작성하니 for문 코드가 이상하게 보입니다. 이 점 양해바랍니다.^^
Forums:
아니요. 안됩니다.
아니요. 안됩니다. 동적메모리를 할당해서 받은 포인터는 직접 모두 지워야합니다.
free(matrix[0]) 하면 matrix[0]만 지워지게 됩니다.
-------------------------------------------------------------------------------
It's better to appear stupid and ask question than to be silent and remain stupid.
-------------------------------------------------------------------------------
It's better to appear stupid and ask question than to be silent and remain stupid.
Pointer 를 다른말로
Pointer 를 다른말로 indirect 라고도 합니다. Computer Architecture 에서 유래된듯 합니다만, 요점은 pointer 자체는 결국 address 를 표현하는 value 를 뜻하고, 그 본체는 한번 건너가야 access 할수 있다는 concept 에서 나온 말입니다. 건너가는걸 * operator 가 하죠.
malloc/free pair 를 이 그림에따라 한번 그려보시면, malloc 한 구역(편의상 A 라고 합니다) 내에 indirect 가 포함될경우, 결국 containing pointer 를 삭제할경우 A 지역이 OS 에 반환되지만, 정작 A 지역내의 content 에 대해서는 신경을 안씁니다. 결국, 그 content 를 관리하는건 프로그래머의 몫이죠.
Cascadable Malloc/Free() 를 만들어 볼수도 있지 않을까 하는 망상이 불현듯 떠오릅니다만... :)
삽질의 대마왕...
삽질의 대마왕...
댓글 달기