include Guard를 사용함에도 불구하고 순환 #include 문제가 지속됩니다. #include 지시문을 처리하는 전처리기가 근본적인 문제를 노출시키는 방식으로 작동하기 때문입니다.
전처리기가 #include 문을 발견하면 이를 지정된 파일의 내용으로 대체합니다. 예를 들어, Physics.h에 GameObject.h가 포함된 경우 전처리기는 Physics.h의 #include "GameObject.h" 행을 GameObject.h의 콘텐츠로 대체합니다.
그러나 GameObject.h도 Physics.h를 포함하면 순환 종속성이 생성됩니다. 전처리기가 GameObject.h에서 #include "Physics.h" 줄을 발견하면 이를 Physics.h의 콘텐츠로 대체하려고 시도하며, 이로 인해 Physics.h에 GameObject.h도 포함되어 있기 때문에 무한 루프가 발생합니다.
이를 더 자세히 이해하려면 다음 코드를 고려하세요.
// Physics.h #ifndef PHYSICS_H #define PHYSICS_H #include "GameObject.h" // Guard is present #endif // GameObject.h #ifndef GAMEOBJECT_H #define GAMEOBJECT_H #include "Physics.h" // Guard is also present #endif
전처리기가 이 코드를 처리하면 다음과 같은 결과가 발생합니다. 다음:
// Physics.h (after preprocessing) #ifndef PHYSICS_H #define PHYSICS_H // (GameObject.h was copy-pasted here) // (GameObject.h was copy-pasted again) #endif // GameObject.h (after preprocessing) #ifndef GAMEOBJECT_H #define GAMEOBJECT_H // (Physics.h was copy-pasted here) // (Physics.h was copy-pasted again) #endif
보시다시피 이제 Physics.h와 GameObject.h 모두 서로의 복사본을 포함하므로 순환 종속성이 발생합니다.
이 문제를 해결하려면 다음을 수행하세요. 순환 #include를 피하고 대신 전방 선언을 사용하는 것이 중요합니다. 전방 선언은 정의를 포함하지 않고 유형의 존재를 선언하므로 컴파일러가 유형의 모든 세부 사항을 요구하지 않고도 작업을 계속할 수 있습니다.
위 내용은 가드를 포함하지 않는 이유는 순환 #include 문제를 방지하는 것입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!