>백엔드 개발 >C++ >C에서 헤더 간의 순환 종속성을 처리하는 방법은 무엇입니까?

C에서 헤더 간의 순환 종속성을 처리하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-10-26 12:11:29518검색

 How to Handle Circular Dependencies Between Headers in C  ?

C에서 서로를 포함하는 헤더

C에서는 헤더가 서로를 포함해야 하는 경우가 있습니다. 그러나 이로 인해 특히 #include 문을 어디에 배치할지에 관한 문제가 발생할 수 있습니다.

매크로 내부 또는 외부

일반적으로 #include 문은 #ifndef와 같은 매크로 안에 배치하면 가드가 포함됩니다. 이렇게 하면 다음 예에서 설명한 것처럼 컴파일 중 무한 재귀가 방지됩니다.

<code class="cpp">// A.h
#ifndef A_H_
#define A_H_

#include "B.h"

class A {
    private:
        B b;
    public:
        A() : b(*this) {}
};

#endif // A_H_</code>
<code class="cpp">// B.h
#ifndef B_H_
#define B_H_

#include "A.h"

class B {
    private:
        A& a;
    public:
        B(A& a) : a(a) {}
};

#endif // B_H_</code>

매크로 외부에 #include 문을 배치하면 A.h와 B.h 사이의 상호 포함으로 인해 컴파일러가 무기한 반복됩니다.

선언되지 않은 유형

그러나 #include 문을 매크로 내에 배치하면 선언되지 않은 유형에 문제가 발생할 수 있습니다. 예를 들어 다음 코드를 고려해보세요.

<code class="cpp">// A.h
#ifndef A_H_
#define A_H_

class A;  // Forward declaration

#include "B.h"

class A {
    private:
        B b;
    public:
        A() : b(*this) {}
};

#endif // A_H_</code>
<code class="cpp">// B.h
#ifndef B_H_
#define B_H_

#include "A.h"

class B {
    private:
        A a;  // Directly include A
    public:
        B(A& a) : a(a) {}
};

#endif // B_H_</code>

이 경우 컴파일러는 A가 B.h 내에서 선언되지 않은 유형이라고 불평합니다. B.h가 포함되면 A.h의 전방 선언이 보이지 않기 때문입니다.

해결책: 전방 선언

이러한 문제를 해결하려면 전방 선언을 사용하는 것이 가장 좋습니다. 필요한 경우 전체 정의가 포함된 헤더를 포함합니다. 이 예에서는 B의 정의 앞에 A의 전방 선언을 B.h에 추가해야 합니다.

<code class="cpp">// B.h
#ifndef B_H_
#define B_H_

class A;  // Forward declaration

#include "A.h"

class B {
    private:
        A a;  // Directly include A
    public:
        B(A& a) : a(a) {}
};

#endif // B_H_</code>

위 내용은 C에서 헤더 간의 순환 종속성을 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.