Windows에서 공유 라이브러리로 작업할 때 함수 내보내기 및 가져오기에 적합한 매크로를 정의해야 합니다. 기존 접근 방식에서는 COMPILING_DLL 매크로를 사용합니다.
COMPILING_DLL 정의
COMPILING_DLL 매크로는 일반적으로 명시적으로 정의되지 않으며 Visual Studio의 기본 동작에 의존합니다. 기본적으로 DLL 프로젝트를 빌드할 때는 정의된 것으로 간주되고 클라이언트 애플리케이션에서 DLL을 사용할 때는 정의되지 않은 것으로 간주됩니다. 그러나 이 접근 방식은 LTDL(로드 시간 동적 연결)을 사용할 때 두 시나리오에 동일한 헤더를 사용할 수 없는 문제가 발생할 수 있습니다.
대체 솔루션
COMPILING_DLL을 사용하는 한 가지 대안은 프로젝트에 로컬로 정의된 기본 매크로를 사용하는 것입니다. 기본적으로 Visual Studio는 현재 프로젝트에 대해 MYDLL_EXPORTS 및 MYDLL_IMPORTS와 같은 매크로를 정의합니다. 이러한 매크로는 다음과 같이 사용할 수 있습니다.
#ifdef MYDLL_EXPORTS /*Enabled as "export" while compiling the dll project*/ #define DLLEXPORT __declspec(dllexport) #else /*Enabled as "import" in the Client side for using already created dll file*/ #define DLLEXPORT __declspec(dllimport) #endif
이 예에서 프로젝트 이름이 "MyDLL"인 경우 MYDLL_EXPORTS 매크로는 DLL 프로젝트를 빌드할 때 정의되고 외부에서 사용할 때는 정의되지 않습니다. 이러한 기본 매크로를 활용하면 COMPILING_DLL의 존재 여부에 의존하지 않고 두 시나리오 모두에 적절하게 DLLEXPORT 매크로를 정의할 수 있습니다.
위 내용은 `COMPILING_DLL`에 의존하지 않고 공유 라이브러리에서 `dllexport`/`dllimport`를 효과적으로 처리하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!