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
함수는 데코레이트된 이름으로 함수를 노출하며, "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 전용 종료