Turbo-C
C++Builder  |  Delphi  |  FireMonkey  |  C/C++  |  Free Pascal  |  Firebird
볼랜드포럼 BorlandForum
 경고! 게시물 작성자의 사전 허락없는 메일주소 추출행위 절대 금지
터보-C 포럼
Q & A
FAQ
팁&트릭
강좌/문서
자료실
Lua 게시판
볼랜드포럼 홈
헤드라인 뉴스
IT 뉴스
공지사항
자유게시판
해피 브레이크
공동 프로젝트
구인/구직
회원 장터
건의사항
운영진 게시판
회원 메뉴
북마크
볼랜드포럼 광고 모집

C/C++ Q/A
[1840] 동적할당 해제에 대해 물어볼께 있습니다.
김동필 [solibo] 1285 읽음    2003-01-16 11:42
List * A;
A = new List;

Node * B;
B = new Node;
이후에 A에 B를 추가하고
Node * C;
C = new Node;
A에 C를 또 추가하고..

즉 A는 B의 주소를 가지고 있고 B는 C의 주소를 가지고 있는
링크드 리스트에서..

만약 이 리스트 전체를 지우고자 할때
delete A 만 하면 B와 C가 가지고 있던 자리들이 모두 delete 되는건지..
아님 B와 C를 먼저 delete 하고 A를 delete 하는건지.. 모르겠네요.

또,
List * D;
D = new List;

A가 가진 주소(B)를 D에게 넘겨줘서..
D를 이용해서 B와 C를 접근하게 할 수 있게 했습니다.
이때 A를 delete 하니
D가 B와 C가 아닌 다른 쓰레기 값을 가지고 있습니다.
왜 그런가요?

소스가 너무 길어서 다 쓰기 힘들어서요.
이렇게 말로 개념만 설명했는데요...
이해가 갈지 모르겠네요..

도와주세요 ^^

+ -

관련 글 리스트
1840 동적할당 해제에 대해 물어볼께 있습니다. 김동필 1285 2003/01/16
1842     Re:동적할당 해제에 대해 물어볼께 있습니다. 남병철.레조 1224 2003/01/16
1849         Re:Re:동적할당 해제에 대해 물어볼께 있습니다. 김동필 1298 2003/01/17
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.