헤더 파일의 다중 정의 오류: 이 문제를 해결하는 이유 및 방법
컴파일러에 여러 정의 오류가 표시되면 "다중 정의" 오류가 발생합니다. 동일한 프로그램에서 기호 정의. 이는 여러 소스 파일에 각각 동일한 기호를 정의하는 동일한 헤더 파일이 포함된 경우 발생할 수 있습니다.
제공된 코드 샘플을 살펴보겠습니다.
// complex.h #include <iostream> class Complex { public: Complex(float Real, float Imaginary); float real() const { return m_Real; }; private: friend std::ostream& operator<< (std::ostream&, const Complex&); float m_Real; float m_Imaginary; }; std::ostream& operator<< (std::ostream& o, const Complex& Cplx) { return o << Cplx.m_Real << " i" << Cplx.m_Imaginary; }
연산자<< 함수는 .h 파일에 정의되어 있으며 여러 소스 파일에 포함되므로 다중 정의의 후보가 됩니다.
// complex.cpp #include "complex.h" Complex::Complex(float Real, float Imaginary) { m_Real = Real; m_Imaginary = Imaginary; }
// main.cpp #include "complex.h" #include <iostream> int main() { Complex Foo(3.4, 4.5); std::cout << Foo << "\n"; return 0; }
이 코드를 컴파일할 때 컴파일러에서 "다중 정의" 오류가 발생합니다. 운영자를 위해<< function.
real()이 아닌 이유는 무엇입니까?
real() 멤버 함수는 암시적으로 인라인됩니다. 즉, 컴파일러는 인라인으로 선언된 것처럼 처리합니다. .h에 명시적으로 지정되지 않았습니다. file.
해결 방법
연산자의 다중 정의 문제를 해결하려면<< 함수에는 두 가지 주요 대안이 있습니다.
함수 인라인:
함수 정의에 inline 키워드를 추가하여 컴파일러에 인라인을 지시합니다.
inline std::ostream& operator<< (std::ostream& o, const Complex& Cplx) { return o << Cplx.m_Real << " i" << Cplx.m_Imaginary; }
정의를 .cpp 파일로 이동:
함수 정의 제거 .h 파일에서 해당 .cpp 파일에 배치합니다.
// complex.cpp std::ostream& operator<< (std::ostream& o, const Complex& Cplx) { return o << Cplx.m_Real << " i" << Cplx.m_Imaginary; }
기타 솔루션
추가 솔루션은 다음과 같습니다.
위 내용은 헤더 파일에 \'다중 정의\' 오류가 발생하는 이유는 무엇이며 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!