자기 참조 구조체

  • 3 minutes to read

C 언어의 구조체(struct)는 여러 개의 데이터 타입을 묶어 하나의 새로운 데이터 타입을 만드는 데 사용됩니다. 이때, 구조체 안에 자기 자신의 타입을 멤버로 갖는 자기 참조 구조체(self-referential struct)를 사용할 수도 있습니다.

전체 소스는 다음과 같습니다.

코드: self_ref_struct.c

#include <stdio.h>

typedef struct ArrayList
{
    char name[25];
    struct ArrayList* next; // 자기 참조 포인터
} ArrayList;

int main(void)
{
    ArrayList* p; // 구조체 포인터 변수
    ArrayList list1 = { "홍길동" };
    ArrayList list2 = { "백두산" };
    ArrayList list3 = { "한라산" };

    list1.next = &list2; // 1~2 구조체 연결
    list2.next = &list3; // 2~3 구조체 연결
    list3.next = NULL;   // 구조체 종결(\0)

    p = &list1; // 첫번째 리스트부터 출력
    while (p != NULL) // 포인터가 널이 아닐 동안 
    {
        printf("%s\n", p->name);
        p = p->next; // 포인터 내용 출력 후 다음 포인터 지정
    }

    return 0;
}
홍길동
백두산
한라산

위 코드에서는 자기 참조 구조체를 이용하여 ArrayList라는 이름의 구조체를 선언하고, 이를 이용하여 리스트를 구현하였습니다. 이 리스트는 다음과 같은 형태를 가지고 있습니다.

list1 -> list2 -> list3 -> NULL

이를 출력하기 위해서는 첫 번째 리스트(list1)부터 시작해서 다음 리스트로 이동해가면서 출력해주어야 합니다. 이를 위해 구조체 포인터 변수를 이용하여 리스트의 첫 번째 노드를 가리키게 하고, 포인터 변수를 이용하여 다음 노드를 계속 찾아가며 출력해줍니다.

ArrayList* p; // 구조체 포인터 변수
ArrayList list1 = { "홍길동" };
ArrayList list2 = { "백두산" };
ArrayList list3 = { "한라산" };

list1.next = &list2; // 1~2 구조체 연결
list2.next = &list3; // 2~3 구조체 연결
list3.next = NULL;   // 구조체 종결(\0)

p = &list1; // 첫번째 리스트부터 출력
while (p != NULL) // 포인터가 널이 아닐 동안 
{
    printf("%s\n", p->name);
    p = p->next; // 포인터 내용 출력 후 다음 포인터 지정
}

이를 실행하면 "홍길동", "백두산", "한라산"이 차례대로 출력됩니다.

이와 같이 자기 참조 구조체를 이용하면 다양한 자료구조를 구현할 수 있습니다. 하지만, 구조체 안에 자기 참조 구조체를 사용하는 경우, 무한 루프(infinite loop)에 빠질 수 있으므로 조심해야 합니다.

더 깊이 공부하고 싶다면
DevLec에서는 실무 중심의 C#, .NET, ASP.NET Core, Blazor, 데이터 액세스 강좌를 단계별로 제공합니다. 현재 수강 가능한 강좌 외에도 더 많은 과정이 준비되어 있습니다.
DevLec.com에서 자세한 커리큘럼을 확인해 보세요.
DevLec 공식 강의
C# Programming
C# 프로그래밍 입문
프로그래밍을 처음 시작하는 입문자를 위한 C# 기본기 완성 과정입니다.
ASP.NET Core 10.0
ASP.NET Core 10.0 시작하기 MVC Fundamentals Part 1 MVC Fundamentals Part 2
웹 애플리케이션의 구조와 MVC 패턴을 ASP.NET Core로 실습하며 익힐 수 있습니다.
Blazor Server
풀스택 웹개발자 과정 Part 1 풀스택 웹개발자 과정 Part 2 풀스택 웹개발자 과정 Part 3
실무에서 바로 활용 가능한 Blazor Server 기반 관리자·포털 프로젝트를 만들어 봅니다.
Data & APIs
Entity Framework Core 시작하기 ADO.NET Fundamentals Blazor Server Fundamentals Minimal APIs
데이터 액세스와 Web API를 함께 이해하면 실무 .NET 백엔드 개발에 큰 도움이 됩니다.
VisualAcademy Docs의 모든 콘텐츠, 이미지, 동영상의 저작권은 박용준에게 있습니다. 저작권법에 의해 보호를 받는 저작물이므로 무단 전재와 복제를 금합니다. 사이트의 콘텐츠를 복제하여 블로그, 웹사이트 등에 게시할 수 없습니다. 단, 링크와 SNS 공유, Youtube 동영상 공유는 허용합니다. www.VisualAcademy.com
박용준 강사의 모든 동영상 강의는 데브렉에서 독점으로 제공됩니다. www.devlec.com