dllexport, dllimport

Microsoft 전용

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

구문

__declspec( dllimport ) declarator
__declspec( dllexport ) declarator

설명

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

클래스가 로 표시 __declspec(dllexport)되면 클래스 계층 구조의 클래스 템플릿 특수화는 암시적으로 로 __declspec(dllexport)표시됩니다. 즉, 클래스 템플릿이 명시적으로 인스턴스화되고 클래스의 멤버를 정의해야 합니다.

dllexport 함수는 데코레이트된 이름으로 함수를 노출하며, "name mangling"으로도 알려져 있습니다. C++ 함수의 경우 데코레이트된 이름에는 형식 및 매개 변수 정보를 인코딩하는 추가 문자가 포함됩니다. 로 선언된 extern "C" C 함수 또는 함수에는 호출 규칙을 기반으로 하는 플랫폼별 장식이 포함됩니다. 호출 규칙을 사용하는 __cdecl 내보낸 C 함수 또는 C++ extern "C" 함수에는 이름 장식이 적용되지 않습니다. C/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++ 키워드