class 안에서 자신을 재사용? 하는 경우
403
작성한 질문수 3
class TreeNode<T>
{
public T Data { get; set; }
public List<TreeNode<T>> Children { get; set; } = new List<TreeNode<T>>();
}
이 부분에서 현재 정의하는 클래스 내부에 자신을 다시 사용하는 것이 왜 가능한 것인가요?(TreeNode 클래스의 정의 내부에 TreeNode가 사용되는 것) 이전부터 이렇게 사용하시길래 그냥 지나가려다가 궁금해서 질문드립니다.
답변 3
4
음~ 리스트는 Generic 때문에 그런거라 살짝 다릅니다.
일단 리스트는 잊으시고 연결 리스트 구현 예제로 살펴보시기 바랍니다.
public class Node
{
public Node _next;
}
요런 느낌으로 되어 있을텐데, 여기서
class Node는 [Node의 설계도를 만들겠다]는 이미이고
안에 있는 Node _next; 는 [동일한 Node 타입의 참조값을 (옵션으로) 들고 있겠다]는 의미입니다.
참조타입의 의미는 실제 데이터가 그 곳에 있는게 아니라,
저 멀리 어딘가에 있는데 단지 그 주소값만 들고 있는다는 개념입니다.
따라서
Node n1 = new Node();
Node n2 = new Node();
로 2개의 객체를 만들어준 다음
n1._next = n2; 와 같이
이미 만들어진 두 객체 사이의 연결 관계를 만들어줄 수가 있습니다.
중첩인형처럼 n1 안에 n2가 포함된 관계가 절대 아니라,
n1의 _next라는 변수가 n2를 가리키는 상황이 된겁니다.
아마도 혼동이 오는 부분은
struct와 같은 값 복사 형식과
class와 같은 참조 형식의 차이 때문일겁니다.
1
그냥 지나가시면 안 되고 반드시 이해를 해야 하는 부분입니다!
사실 노드형 자료구조를 사용하다 보면 거의 저런 패턴이 등장하는데요.
(List의 Node도 그렇고, Vertex도 그렇고..)
처음 볼 땐 누구나 의문이 드는 부분입니다!
TreeNode이라는 애를 설계를 하는데,
그 안에 TreeNode가 있으니 이게 말이 되나 싶기도 하고
뭔가 중첩인형 생각이 나는데요.
사실 C++의 포인터 혹은 C#의 참조 타입을
정확하게 이해하고 있어야만 그림이 그려지는 부분이기도 합니다.
class TreeNode는 [TreeNode라는 이름의 클래스 설계도를 만들겠다]로 분석을 해야 하고,
그 외 TreeNode는 [또 다른 TreeNode 객체를 가리키는(!!!) 참조값(주소값)]으로 이해하면 수월합니다.
참조값은 말 그대로 다른 아이의 주소를 저장하는 용도이지
실제로 그 객체가 안에 있다는 의미가 아닙니다.
그러니 이미 만들어진 TreeNode끼리의 상호 연결 관계를 Children을 통해 연결하는 개념이지,
TreeNode 안에 또 다른 TreeNode가 있다는 것은 아닙니다.
게임개발에서 주로 어느부분에 알고리즘들이 쓰이는지 궁금합니다
0
170
2
글꼴 바꿔도 자간이 좁아 찌그러져보이시는 분들
0
87
1
NullReferenceException 예외) 같은 실수하시는분 계실까봐 남겨요
0
66
1
parent를 Pos타입으로 만든 이유
0
74
1
콘솔창에 격자가 안나옴 미로 생성 X
0
133
1
격자 생성 안됨 무한루프
0
113
1
BFS 질문
0
143
2
격자 무한 출력
0
166
2
A* 의 PriorityQueue 관련 질문입니다
0
155
2
vscode에서 원그리기
0
179
1
환결설정 강의 원 그리기
0
122
1
15-17분
0
86
1
3:16초에 근데 이렇게 해가지고 부분에 "{}"를 만들어서 자식 node들을 생성하던데 왜 중괄호로 감싸게 만드는 건가요?
0
141
2
동적 배열 관련 질문입니다!
0
209
1
Big-o 표기법에서 시간 복잡도
0
167
1
7:40에서 언급하신 색상이 날아가는 문제 이해를 못하겠습니다
0
151
1
트리구현연습 강의 질문있어요
0
142
1
창은 뜨는데 맵이 나타나지 않아요.
0
174
1
Ctrl F5 하면 나오는 창은 어디서 설정할까요??
0
271
1
void CalcPathFromParent(Pos[,] parent)에 대해서
0
202
2
NullReferenceException예외가 발생했을때 어떻게 해야하나요?
0
228
1
[해결] 환경설정 강의에서 원이 이상하게 그려지는 문제
3
309
2
오른손 법칙에서 플레이어 점이 안 움직입니다
0
243
2
맵 만들기 오류
0
178
1





