dllexport, dllimport

Microsoft 전용

dllexport 스토리지 클래스 특성 및 dllimport 스토리지 클래스 특성은 C 및 C++ 언어에 대한 Microsoft 관련 확장입니다. 이러한 특성을 사용하여 함수, 데이터 및 개체를 DLL에 내보내거나 DLL에서 가져올 수 있습니다.

구문

   __declspec( dllimport ) declarator
   __declspec( dllexport ) declarator

설명

이러한 특성은 실행 파일이나 다른 DLL일 수 있는 클라이언트에 대한 DLL 인터페이스를 명시적으로 정의합니다. 함수를 로 dllexport 선언하면 적어도 내보낸 함수의 사양과 관련하여 모듈 정의(.def) 파일이 필요하지 않습니다. 특성은 dllexport__export 키워드를 대체합니다.

클래스가 declspec(dllexport)로 표시된 경우 클래스 계층 구조에 있는 클래스 템플릿의 특수화는 암시적으로 declspec(dllexport)로 표시됩니다. 이는 클래스 템플릿이 명시적으로 인스턴스화되었으며 클래스의 멤버가 정의되어야 함을 의미합니다.

dllexport 의 함수는 데코레이팅된 이름으로 함수를 노출합니다. C++ 함수의 경우 여기에 이름 변환이 포함됩니다. C 함수 또는 extern "C"로 선언된 함수의 경우 여기에 호출 규칙을 기반으로 하는 플랫폼별 데코레이션이 포함됩니다. C/C++ 코드의 이름 장식에 대한 자세한 내용은 데코레이트된 이름을 참조하세요. __cdecl 호출 규칙을 사용하여 내보낸 C 함수 또는 C++ extern "C" 함수에는 이름 데코레이션이 적용되지 않습니다.

데코레이트되지 않은 이름을 내보내려면 EXPORTS 섹션에서 데코레이트되지 않은 이름을 정의하는 모듈 정의(.def) 파일을 사용하여 연결할 수 있습니다. 자세한 내용은 EXPORTS를 참조하세요. 비코칭 이름을 내보내는 또 다른 방법은 소스 코드에서 지시문을 사용하는 #pragma comment(linker, "/export:alias=decorated_name") 것입니다.

선언하거나 dllimport선언 dllexport 할 때 확장 특성 구문과 키워드를 __declspec 사용해야 합니다.

예제

// Example of the dllimport and dllexport class attributes
__declspec( dllimport ) int i;
__declspec( dllexport ) void func();

또는 매크로 정의를 사용하여 코드를 보다 읽기 쉽게 만들 수 있습니다.

#define DllImport   __declspec( dllimport )
#define DllExport   __declspec( dllexport )

DllExport void func();
DllExport int i = 10;
DllImport int j;
DllExport int n;

자세한 내용은 다음을 참조하세요.

Microsoft 전용 종료

참조

__declspec
C++ 키워드