원본 : http://www.debuglab.com/knowledge/mfcdll.html
1.요약
MFC 라이브러리에 DLL을 동적으로 링크하는 방법을 알아보도록 합니다.
2.본문
마이크로소프트는 DLL을 크게 동적으로 링크된 DLL과 MFC 라이브러리에 정적으로 링크된 DLL의 두 가지로 분류해 놓았다. 다음의 예는 마이크로소프트에서 제공한 MFC 라이브러리에 DLL을 동적으로 링크할 수 있도록 수정해 주는 내용이다.
정규 DLL은 내부적으로 MFC를 사용하도록 동적으로 MFC 라이브러리에 링크된 DLL이다. 내보내지는 DLL 함수들은 MFC로 호출되거나 MFC 실행 가능 프로그램이 아닌 경우 다음과 같은 형태를 취하게 된다.
- DLL은 MFC DLL에 동적으로 링크되어 있다.
- DLL을 지원하는 언어를 사용한다면 호스트 프로그램은 DLL을 사용할 수 있고, 꼭 MFC 기반의 프로그램이 아니어도 괜찮다.
- 이 DLL에 링크되는 MFC import 라이브러리는 확장 DLL에 이용되는 것과 동일하거나, MFC DLL을 사용하는 프로그램이다.
정규 DLL을 MFC에 동적으로 링크하기 위해서는 다음의 조건을 만족해야 한다.
1. 정규 DLL은 반드시 CWinApp 파생 클래스와 그 프로그램 클래스의 단일 객체 클래스를 가져야 한다. DLL의 CWinApp 객체는 주된 메시지 펌프를 가지고 있지 않다. 이로 인해 CWinApp 객체와 일반적인 프로그램간에 차이가 발생한다.
2. _AFXDLL가 정의된 상태로 DLL이 컴파일 되어야 한다. 이것은 동적으로 MFC DLL에 링크된 실행 프로그램에 _USRDLL이 정의되는 것과 비슷하다.
3. DLL은 CWinApp 파생 클래스의 실행 예로 설명되어야 한다.
4. MFC에 의해 지원되는 DllMain을 사용해야 한다. 모든 DLL 초기화 코드는 InitInstance() 멤버 함수에 위치하고, 종료 코드는 ExitInstance() 멤버 함수에 위치해야 한다.
5. DLL에서 가용한 모든 함수의 첫 부분에는 AFX_MANAGE_STATE 매크로를 사용해야 한다. 이것은 DLL의 타입이 MFC 버전의 DLL을 사용하기 때문이다.
MFCx0.dll 과 MSVCRT.dll(혹은 비슷한 파일들)은 프로그램과 함께 배포되어야 한다.
표준 C 인터페이스를 사용해 정규 DLL로부터 심볼들을 내보낼 수 있다. 그 인터페이스는 다음과 같은 형태로 주어진다.
MFC에 동적으로 링크된 DLL은 MFC 모듈 상태를 정확히 바꾸기 위해 AFX_MANAGE_STATE 매크로를 사용한다. 이 코드는 DLL로부터 내보내지는 모든 함수의 첫머리에 다음과 같은 형태로 추가되어야 한다.
3.예제
4.참고
- DeBUGGING C++(번역서) 475~476 페이지
- 2001.08.19 Smile Seo -
1.요약
MFC 라이브러리에 DLL을 동적으로 링크하는 방법을 알아보도록 합니다.
2.본문
마이크로소프트는 DLL을 크게 동적으로 링크된 DLL과 MFC 라이브러리에 정적으로 링크된 DLL의 두 가지로 분류해 놓았다. 다음의 예는 마이크로소프트에서 제공한 MFC 라이브러리에 DLL을 동적으로 링크할 수 있도록 수정해 주는 내용이다.
정규 DLL은 내부적으로 MFC를 사용하도록 동적으로 MFC 라이브러리에 링크된 DLL이다. 내보내지는 DLL 함수들은 MFC로 호출되거나 MFC 실행 가능 프로그램이 아닌 경우 다음과 같은 형태를 취하게 된다.
- DLL은 MFC DLL에 동적으로 링크되어 있다.
- DLL을 지원하는 언어를 사용한다면 호스트 프로그램은 DLL을 사용할 수 있고, 꼭 MFC 기반의 프로그램이 아니어도 괜찮다.
- 이 DLL에 링크되는 MFC import 라이브러리는 확장 DLL에 이용되는 것과 동일하거나, MFC DLL을 사용하는 프로그램이다.
정규 DLL을 MFC에 동적으로 링크하기 위해서는 다음의 조건을 만족해야 한다.
1. 정규 DLL은 반드시 CWinApp 파생 클래스와 그 프로그램 클래스의 단일 객체 클래스를 가져야 한다. DLL의 CWinApp 객체는 주된 메시지 펌프를 가지고 있지 않다. 이로 인해 CWinApp 객체와 일반적인 프로그램간에 차이가 발생한다.
2. _AFXDLL가 정의된 상태로 DLL이 컴파일 되어야 한다. 이것은 동적으로 MFC DLL에 링크된 실행 프로그램에 _USRDLL이 정의되는 것과 비슷하다.
3. DLL은 CWinApp 파생 클래스의 실행 예로 설명되어야 한다.
4. MFC에 의해 지원되는 DllMain을 사용해야 한다. 모든 DLL 초기화 코드는 InitInstance() 멤버 함수에 위치하고, 종료 코드는 ExitInstance() 멤버 함수에 위치해야 한다.
5. DLL에서 가용한 모든 함수의 첫 부분에는 AFX_MANAGE_STATE 매크로를 사용해야 한다. 이것은 DLL의 타입이 MFC 버전의 DLL을 사용하기 때문이다.
MFCx0.dll 과 MSVCRT.dll(혹은 비슷한 파일들)은 프로그램과 함께 배포되어야 한다.
표준 C 인터페이스를 사용해 정규 DLL로부터 심볼들을 내보낼 수 있다. 그 인터페이스는 다음과 같은 형태로 주어진다.
extern "C" __declspec(dllexport) ExportFunctionName();정규 DLL내의 모든 메모리 위치 지정은 반드시 그 DLL 내부에 있어야 한다.
MFC에 동적으로 링크된 DLL은 MFC 모듈 상태를 정확히 바꾸기 위해 AFX_MANAGE_STATE 매크로를 사용한다. 이 코드는 DLL로부터 내보내지는 모든 함수의 첫머리에 다음과 같은 형태로 추가되어야 한다.
AFX_MANAGE_STATE(AfxGetStaticModuleState())이 매크로는 정적으로 MFC에 링크된 확장 DLL이나 정규 DLL에 사용되어서는 안된다.
3.예제
4.참고
- DeBUGGING C++(번역서) 475~476 페이지
- 2001.08.19 Smile Seo -
"MFC" 카테고리의 다른 글
- Dll Rebase 시키기 (0)2007/03/21
- Delayload 적용시키기 (0)2007/03/21
- MFC 라이브러리에 동적으로 링크된 정규 DLL (0)2007/03/21
- 대용량의 파일 순식간에 읽기 (0)2007/03/21
- Edit 컨트롤에서 Tab 키 넣기 (0)2007/03/21

수안이의 컴퓨터 연구실



Leave your greetings.