애플리케이션 정보 및 관리
애플리케이션을 작성할 때 단일 CWinApp
파생 개체를 만듭니다. 때때로 파생 개체 외부에서 이 개체에 CWinApp
대한 정보를 가져올 수 있습니다. 또는 다른 전역 "관리자" 개체에 액세스해야 할 수도 있습니다.
Microsoft Foundation 클래스 라이브러리는 이러한 작업을 수행하는 데 도움이 되는 다음과 같은 전역 함수를 제공합니다.
애플리케이션 정보 및 관리 함수
속성 | 설명 |
---|---|
AfxBeginThread |
새 스레드를 만듭니다. |
AfxContextMenuManager |
전역 상황에 맞는 메뉴 관리자에 대한 포인터입니다. |
AfxEndThread |
현재 스레드를 종료합니다. |
AfxFindResourceHandle |
리소스 체인을 안내하고 리소스 ID 및 리소스 종류별로 특정 리소스를 찾습니다. |
AfxFreeLibrary |
로드된 DLL(동적 연결 라이브러리) 모듈의 참조 수를 줄입니다. 참조 수가 0에 도달하면 모듈의 매핑이 해제됩니다. |
AfxGetApp |
애플리케이션의 단일 CWinApp 개체에 대한 포인터를 반환합니다. |
AfxGetAppName |
애플리케이션의 이름을 포함하는 문자열을 반환합니다. |
AfxGetInstanceHandle |
애플리케이션의 HINSTANCE 이 인스턴스를 나타내는 값을 반환합니다. |
AfxGetMainWnd |
OLE가 아닌 애플리케이션의 현재 "main" 창 또는 서버 애플리케이션의 현재 위치 프레임 창에 대한 포인터를 반환합니다. |
AfxGetPerUserRegistration |
이 함수를 사용하여 애플리케이션이 (HKCU ) 노드에 대한 레지스트리 액세스를 HKEY_CURRENT_USER 리디렉션하는지 여부를 확인합니다. |
AfxGetResourceHandle |
HINSTANCE 애플리케이션의 기본 리소스 원본을 반환합니다. 애플리케이션의 리소스에 직접 액세스하는 데 사용합니다. |
AfxGetThread |
현재 CWinThread 개체에 대한 포인터를 검색합니다. |
AfxInitRichEdit |
애플리케이션에 대한 버전 1.0 리치 편집 컨트롤을 초기화합니다. |
AfxInitRichEdit2 |
애플리케이션에 대한 버전 2.0 이상 서식 있는 편집 컨트롤을 초기화합니다. |
AfxIsExtendedFrameClass |
지정된 창이 확장된 프레임 개체인지 여부를 확인합니다. |
AfxIsMFCToolBar |
지정된 창이 도구 모음 개체인지 여부를 확인합니다. |
AfxKeyboardManager |
전역 키보드 관리자에 대한 포인터입니다. |
AfxLoadLibrary |
DLL 모듈을 매핑하고 DLL 함수의 주소를 가져오는 데 사용할 수 있는 핸들을 반환합니다. |
AfxLoadLibraryEx |
지정된 옵션을 사용하여 DLL 모듈을 매핑하고 DLL 함수의 주소를 가져오는 데 사용할 수 있는 핸들을 반환합니다. |
AfxMenuTearOffManager |
전역 분리 메뉴 관리자에 대한 포인터입니다. |
AfxMouseManager |
전역 마우스 관리자에 대한 포인터입니다. |
AfxRegisterClass |
MFC를 사용하는 DLL에 창 클래스를 등록합니다. |
AfxRegisterWndClass |
Windows 창 클래스를 등록하여 MFC에 의해 자동으로 등록된 클래스를 보완합니다. |
AfxSetPerUserRegistration |
애플리케이션이 (HKCU ) 노드에 대한 레지스트리 액세스를 HKEY_CURRENT_USER 리디렉션하는지 여부를 설정합니다. |
AfxSetResourceHandle |
애플리케이션의 기본 리소스가 로드되는 HINSTANCE 핸들을 설정합니다. |
AfxShellManager |
전역 셸 관리자에 대한 포인터입니다. |
AfxSocketInit |
Windows 소켓을 CWinApp::InitInstance 초기화하기 위해 재정의에서 호출됩니다. |
AfxUserToolsManager |
전역 사용자 도구 관리자에 대한 포인터입니다. |
AfxWinInit |
MFC를 초기화하기 위해 GUI 기반 애플리케이션 초기화의 CWinApp 일부로 MFC 제공 WinMain 함수에 의해 호출됩니다. MFC를 사용하는 콘솔 애플리케이션에 대해 직접 호출해야 합니다. |
AfxBeginThread
이 함수를 호출하여 새 스레드를 만듭니다.
CWinThread* AfxBeginThread(
AFX_THREADPROC pfnThreadProc,
LPVOID pParam,
int nPriority = THREAD_PRIORITY_NORMAL,
UINT nStackSize = 0,
DWORD dwCreateFlags = 0,
LPSECURITY_ATTRIBUTES lpSecurityAttrs = NULL);
CWinThread* AfxBeginThread(
CRuntimeClass* pThreadClass,
int nPriority = THREAD_PRIORITY_NORMAL,
UINT nStackSize = 0,
DWORD dwCreateFlags = 0,
LPSECURITY_ATTRIBUTES lpSecurityAttrs = NULL);
매개 변수
pfnThreadProc
작업자 스레드에 대한 제어 함수를 가리킵니다. 포인터가 될 NULL
수 없습니다. 이 함수는 다음과 같이 선언해야 합니다.
UINT __cdecl MyControllingFunction( LPVOID pParam );
pThreadClass
RUNTIME_CLASS
에서 파생된 개체의 형식입니다CWinThread
.
pParam
제어 함수에 전달할 매개 변수입니다.
nPriority
스레드에 대해 설정할 우선 순위입니다. 사용 가능한 우선 순위에 대한 전체 목록 및 설명은 Windows SDK를 참조 SetThreadPriority
하세요.
nStackSize
새 스레드에 대한 스택의 크기(바이트)를 지정합니다. 0이면 스택 크기는 기본적으로 만드는 스레드와 동일한 크기 스택으로 설정됩니다.
dwCreateFlags
스레드 생성을 제어하는 추가 플래그를 지정합니다. 이 플래그는 다음 두 값 중 하나를 포함할 수 있습니다.
CREATE_SUSPENDED
일시 중단 횟수 1로 스레드를 시작합니다. 스레드가 실행되기 전에 개체의CWinThread
멤버 데이터(예:m_bAutoDelete
파생 클래스의 멤버)를 초기화하려는 경우에 사용합니다CREATE_SUSPENDED
. 초기화가 완료되면 스레드 실행을 시작하는 데 사용합니다CWinThread::ResumeThread
. 스레드는 호출될 때까지CWinThread::ResumeThread
실행되지 않습니다.0 만든 직후 스레드를 시작합니다.
lpSecurityAttrs
스레드의 SECURITY_ATTRIBUTES
보안 특성을 지정하는 구조를 가리킵니다. 이 경우 NULL
만드는 스레드와 동일한 보안 특성이 사용됩니다. 이 구조에 대한 자세한 내용은 Windows SDK를 참조하세요.
Return Value
새로 만든 스레드 개체에 대한 포인터이거나 NULL
오류가 발생하는 경우
설명
첫 번째 형식은 AfxBeginThread
작업자 스레드를 만듭니다. 두 번째 양식은 사용자 인터페이스 스레드 또는 작업자 스레드로 사용할 수 있는 스레드를 만듭니다.
AfxBeginThread
는 새 CWinThread
개체를 만들고, 해당 CreateThread
함수를 호출하여 스레드 실행을 시작하고, 스레드에 대한 포인터를 반환합니다. 생성의 일부가 실패할 경우 모든 개체의 할당이 제대로 취소되었는지 확인하기 위해 프로시저 전체에서 검사가 수행됩니다. 스레드를 종료하려면 스레드 내에서 호출 AfxEndThread
하거나 작업자 스레드의 제어 함수에서 반환합니다.
애플리케이션에서 다중 스레딩을 사용하도록 설정해야 합니다. 그렇지 않으면 이 함수가 실패합니다. 다중 스레딩/MD
을 사용하도록 설정하는 방법에 대한 자세한 내용은 , /MT
/LD
(런타임 라이브러리 사용)을 참조하세요.
자세한 AfxBeginThread
내용은 다중 스레딩: 작업자 스레드 만들기 및 다중 스레딩: 사용자 인터페이스 스레드 만들기 문서를 참조하세요.
예시
CSocket::Attach
에 대한 예를 참조하세요.
요구 사항
머리글 afxwin.h
AfxContextMenuManager
전역 상황에 맞는 메뉴 관리자에 대한 포인터입니다.
구문
CContextMenuManager* afxContextMenuManager;
요구 사항
머리글: afxcontextmenumanager.h
AfxEndThread
이 함수를 호출하여 현재 실행 중인 스레드를 종료합니다.
void AFXAPI AfxEndThread(
UINT nExitCode,
BOOL bDelete = TRUE);
매개 변수
nExitCode
스레드의 종료 코드를 지정합니다.
bDelete
메모리에서 스레드 개체를 삭제합니다.
설명
종료하려면 스레드 내에서 호출해야 합니다.
자세한 AfxEndThread
내용은 다중 스레딩: 스레드 종료 문서를 참조하세요.
요구 사항
머리글 afxwin.h
AfxFindResourceHandle
리소스 체인을 안내하고 리소스 ID 및 리소스 종류별로 특정 리소스를 찾는 데 사용합니다 AfxFindResourceHandle
.
구문
HINSTANCE AFXAPI AfxFindResourceHandle( LPCTSTR lpszName, LPCTSTR lpszType );
매개 변수
lpszName
리소스 ID를 포함하는 문자열에 대한 포인터입니다.
lpszType
리소스 유형에 대한 포인터입니다. 리소스 종류 목록은 Windows SDK를 참조 FindResource
하세요.
Return Value
리소스를 포함하는 모듈에 대한 핸들입니다.
설명
AfxFindResourceHandle
는 특정 리소스를 찾고 리소스가 포함된 모듈에 대한 핸들을 반환합니다. 리소스가 로드된 모든 MFC 확장 DLL에 있을 수 있습니다. AfxFindResourceHandle
는 리소스가 있는 항목을 알려줍니다.
모듈은 다음 순서로 검색됩니다.
MFC 확장 DLL인 경우 주 모듈입니다.
비 시스템 모듈.
언어별 모듈.
기본 모듈(시스템 DLL인 경우)입니다.
시스템 모듈.
요구 사항
머리글: afxwin.h
AfxFreeLibrary
AfxFreeLibrary
및 AfxLoadLibrary
는 각 코딩된 라이브러리 모듈에 대한 참조 횟수를 유지 관리합니다.
BOOL AFXAPI AfxFreeLibrary(HINSTANCE hInstLib);
매개 변수
hInstLib
로드된 라이브러리 모듈의 핸들입니다. AfxLoadLibrary
는 이 핸들을 반환합니다.
Return Value
TRUE
함수가 성공하면
설명
AfxFreeLibrary
는 로드된 DLL(동적 연결 라이브러리) 모듈의 참조 횟수를 감소시킵니다. 참조 횟수가 0에 도달하면, 호출 프로세스의 주소 공간에서 모듈이 매핑 해제되고 핸들이 더 이상 유효하지 않습니다. 이 참조 카운트는 AfxLoadLibrary
가 호출될 때마다 매번 증가합니다.
라이브러리 모듈을 매핑 해제하기 전에 시스템은 DLL이 이를 사용하는 프로세스에서 분리할 수 있게 해줍니다. 이렇게 하면 DLL이 현재 프로세스에 할당된 리소스를 정리할 수 있습니다. 진입점 함수가 반환된 다음 라이브러리 모듈은 현재 프로세스의 주소 공간에서 제거됩니다.
AfxLoadLibrary
를 사용해서 DLL 모듈을 매핑합니다.
애플리케이션에서 여러 스레드를 사용하는 AfxFreeLibrary
AfxLoadLibrary
경우 Win32 함수 FreeLibrary
LoadLibrary
대신 사용해야 합니다. MFC 확장 DLL이 로드되고 AfxFreeLibrary
언로드될 때 실행되는 시작 및 종료 코드가 전역 MFC 상태를 손상시키지 않도록 합니다AfxLoadLibrary
.
예시
AfxLoadLibrary
에 대한 예를 참조하세요.
요구 사항
머리글 afxdll_.h
AfxGetApp
이 함수에서 반환된 포인터를 사용하여 기본 메시지 디스패치 코드 또는 맨 위 창과 같은 애플리케이션 정보에 액세스할 수 있습니다.
CWinApp* AFXAPI AfxGetApp();
Return Value
애플리케이션의 단일 CWinApp
개체에 대한 포인터입니다.
설명
이 메서드가 반환 NULL
되면 애플리케이션 주 창이 아직 완전히 초기화되지 않았음을 나타낼 수 있습니다. 문제가 있음을 나타낼 수도 있습니다.
예시
// Print the application's executable filename.
TRACE(_T("Executable filename = %s\n"), AfxGetApp()->m_pszExeName);
요구 사항
머리글 afxwin.h
AfxGetAppName
반환된 문자열은 진단 메시지 또는 임시 문자열 이름의 루트로 사용할 수 있습니다.
LPCTSTR AFXAPI AfxGetAppName();
Return Value
애플리케이션의 이름을 포함하는 null로 끝나는 문자열입니다.
예시
// Print the application name to the debugger output window.
TRACE(_T("Application name is %s\n"), AfxGetAppName());
요구 사항
머리글 afxwin.h
AfxGetInstanceHandle
이 함수를 사용하면 현재 애플리케이션의 인스턴스 핸들을 검색할 수 있습니다.
HINSTANCE AFXAPI AfxGetInstanceHandle();
Return Value
HINSTANCE
애플리케이션의 현재 인스턴스에 대한 것입니다. MFC HINSTANCE
의 USRDLL 버전과 연결된 DLL 내에서 호출되는 경우 DLL에 대한 값이 반환됩니다.
설명
AfxGetInstanceHandle
MFC의 USRDLL 버전과 연결된 DLL 내에서 호출되지 않는 한 항상 실행 파일(.EXE)을 반환 HINSTANCE
합니다. 이 경우 DLL에 HINSTANCE
반환됩니다.
예시
// Print the application instance handle to the debugger output window.
TRACE(_T("Application instance handle is 0x%0X\n"), AfxGetInstanceHandle());
요구 사항
머리글 afxwin.h
AfxGetMainWnd
애플리케이션이 OLE 서버인 경우 이 함수를 호출하여 애플리케이션의 활성 주 창에 대한 포인터를 검색합니다. 애플리케이션 개체의 멤버를 직접 참조하는 m_pMainWnd
대신 이 결과를 사용합니다.
CWnd* AFXAPI AfxGetMainWnd();
Return Value
현재 컨테이너 내에서 현재 위치에 활성 상태인 개체가 서버에 있는 경우 현재 위치 활성 문서를 포함하는 프레임 창 개체에 대한 포인터를 반환합니다.
컨테이너 내에서 활성 상태인 개체가 없거나 애플리케이션이 OLE 서버가 아닌 경우 이 함수는 애플리케이션 개체의 반환을 반환 m_pMainWnd
합니다.
애플리케이션의 기본 스레드에서 AfxGetMainWnd
가 호출되는 경우 위의 규칙에 따라 애플리케이션의 주 창이 반환됩니다. 함수가 애플리케이션의 보조 스레드에서 호출되면 함수는 호출한 스레드에 연결된 주 창을 반환합니다.
설명
애플리케이션이 OLE 서버가 아닌 경우 이 함수를 호출하는 것은 애플리케이션 개체의 멤버를 직접 참조하는 m_pMainWnd
것과 같습니다.
예시
//The following line send a WM_CLOSE message
// to the Application's main window. This will cause the
// Application to exit.
AfxGetMainWnd()->PostMessage(WM_CLOSE, 0, 0);
요구 사항
머리글 afxwin.h
AfxGetPerUserRegistration
이 함수를 사용하여 애플리케이션이 (HKCU
) 노드에 대한 레지스트리 액세스를 HKEY_CURRENT_USER
리디렉션하는지 여부를 확인합니다.
BOOL AFXAPI AfxGetPerUserRegistration();
Return Value
TRUE
는 레지스트리 정보가 노드로 전달됨을 HKCU
나타냅니다. FALSE
는 애플리케이션이 기본 노드에 레지스트리 정보를 씁니다. 기본 노드는 (HKCR
)입니다 HKEY_CLASSES_ROOT
.
설명
레지스트리 리디렉션을 사용하도록 설정하면 프레임워크가 액세스를 .로 HKCR
HKEY_CURRENT_USER\Software\Classes
리디렉션합니다. MFC 및 ATL 프레임워크만 리디렉션의 영향을 받습니다.
애플리케이션이 레지스트리 액세스를 리디렉션하는지 여부를 변경하려면 .를 사용합니다 AfxSetPerUserRegistration
.
요구 사항
머리글 afxstat_.h
AfxGetResourceHandle
이 함수에서 HINSTANCE
반환된 핸들을 사용하여 애플리케이션의 리소스에 직접 액세스합니다(예: Windows 함수 FindResource
호출).
extern HINSTANCE AfxGetResourceHandle();
Return Value
HINSTANCE
애플리케이션의 기본 리소스가 로드되는 핸들입니다.
예시
//Load the menu specifying the module handle where resource is to be
//found & resource ID
HMENU hMenu = ::LoadMenu(AfxGetResourceHandle(), MAKEINTRESOURCE(IDR_MAINFRAME));
요구 사항
머리글 afxwin.h
AfxGetThread
이 함수를 호출하여 현재 실행 중인 스레드를 CWinThread
나타내는 개체에 대한 포인터를 가져옵니다.
CWinThread* AfxGetThread();
Return Value
현재 실행 중인 스레드에 대한 포인터입니다. 그렇지 않으면 NULL
.
설명
스레드 내에서 호출해야 합니다.
참고 항목
Visual C++ 버전 4.2, 5.0 또는 6.0 AfxGetThread
에서 호출하는 AfxGetThread
MFC 프로젝트를 포팅하는 경우 스레드가 없는 경우 호출 AfxGetApp
합니다. 최신 버전의 컴파일러 AfxGetThread
에서 스레드가 없는 경우 반환합니다 NULL
. 애플리케이션 스레드를 원하는 경우 호출 AfxGetApp
해야 합니다.
예시
//Print the current thread ID in the Debug Window
TRACE(_T("Current Thread ID = 0x%X\n"), AfxGetThread()->m_nThreadID);
요구 사항
머리글 afxwin.h
AfxInitRichEdit
이 함수를 호출하여 애플리케이션에 대한 서식 있는 편집 컨트롤(버전 1.0)을 초기화합니다.
BOOL AFXAPI AfxInitRichEdit();
설명
이 함수는 이전 버전과의 호환성을 위해 제공됩니다. 새 애플리케이션은 .를 사용해야 AfxInitRichEdit2
합니다.
AfxInitRichEdit
RICHED32.DLL
를 로드하여 서식 있는 편집 컨트롤의 버전 1.0을 초기화합니다. 서식 있는 편집 컨트롤 RICHED20.DLL
의 버전 2.0 및 3.0을 사용하려면 로드해야 합니다. 를 호출하여 로드됩니다 AfxInitRichEdit2
.
기존 Visual C++ 애플리케이션의 서식 있는 편집 컨트롤을 버전 2.0으로 업데이트하려면 을 엽니다. RC 파일을 텍스트로 사용하여 각 서식 있는 편집 컨트롤의 클래스 이름을 ""에서 "RICHEDIT
RichEdit20a
"로 변경합니다. 그런 다음 호출 AfxInitRichEdit
AfxInitRichEdit2
을 .
또한 이 함수는 라이브러리가 프로세스에 대해 아직 초기화되지 않은 경우 공용 컨트롤 라이브러리를 초기화합니다. MFC 애플리케이션에서 직접 리치 편집 컨트롤을 사용하는 경우 MFC가 리치 편집 컨트롤 런타임을 제대로 초기화했는지 확인하기 위해 이 함수를 호출합니다. 또는 메서드를 Create
CRichEditCtrl
CRichEditView
CRichEditDoc
호출하는 경우 일반적으로 이 함수를 호출할 필요가 없지만 경우에 따라 필요할 수 있습니다.
요구 사항
머리글 afxwin.h
AfxInitRichEdit2
이 함수를 호출하여 애플리케이션에 대한 다양한 편집 컨트롤(버전 2.0 이상)을 초기화합니다.
BOOL AFXAPI AfxInitRichEdit2();
설명
이 함수를 호출하여 서식 있는 편집 컨트롤의 버전 2.0을 로드 RICHED20.DLL
하고 초기화합니다. 또는 메서드를 Create
CRichEditCtrl
CRichEditView
CRichEditDoc
호출하는 경우 일반적으로 이 함수를 호출할 필요가 없지만 경우에 따라 필요할 수 있습니다.
요구 사항
머리글 afxwin.h
AfxIsExtendedFrameClass
지정된 창이 확장된 프레임 개체인지 여부를 확인합니다.
구문
BOOL AFXAPI AfxIsExtendedFrameClass( CWnd* pWnd );
매개 변수
pWnd
[in] 에서 파생된 CWnd
개체에 대한 포인터입니다.
Return Value
TRUE
제공된 창이 확장 프레임 개체이면 이고, 그렇지 않으면 FALSE
.
설명
이 메서드는 TRUE
가 다음 클래스 중 하나에서 파생되는 경우 pWnd
를 반환합니다.
CFrameWndEx
CMDIFrameWndEx
COleIPFrameWndEx
COleDocIPFrameWndEx
CMDIChildWndEx
이 메서드는 함수 또는 메서드 매개 변수가 확장된 프레임 창인지 확인해야 하는 경우에 유용합니다.
요구 사항
머리글: afxpriv.h
AfxIsMFCToolBar
지정된 창이 도구 모음 개체인지 여부를 확인합니다.
구문
BOOL AFXAPI AfxIsMFCToolBar(CWnd* pWnd);
매개 변수
pWnd
[in] 에서 파생된 CWnd
개체에 대한 포인터입니다.
Return Value
TRUE
제공된 창이 도구 모음 개체이면 이고, 그렇지 않으면 FALSE
.
설명
에서 파생된 경우 pWnd
이 메서드가 반환 TRUE
됩니다CMFCToolBar
. 이 메서드는 함수 또는 메서드 매개 변수 CMFCToolBar
가 개체인지 확인해야 하는 경우에 유용합니다.
요구 사항
머리글: afxpriv.h
AfxKeyboardManager
전역 키보드 관리자에 대한 포인터입니다.
구문
CKeyboardManager* afxKeyboardManager;
요구 사항
머리글: afxkeyboardmanager.h
AfxLoadLibrary
AfxLoadLibrary
를 사용해서 DLL 모듈을 매핑합니다.
HINSTANCE AFXAPI AfxLoadLibrary(LPCTSTR lpszModuleName);
매개 변수
lpszModuleName
모듈의 이름(.DLL 또는 .EXE 파일)이 포함된 null로 끝나는 문자열을 가리킵니다. 지정된 이름은 모듈의 파일 이름입니다.
문자열이 경로를 지정하지만 지정된 디렉터리에 파일이 없으면 함수가 실패합니다.
경로를 지정하지 않고 파일 이름 확장명은 생략하면 기본 확장명 .DLL 추가됩니다. 그러나 파일 이름 문자열에는 모듈 이름에 확장명 없음을 나타내는 후행 지점 문자(.)가 포함될 수 있습니다. 경로가 지정되지 않은 경우 함수는 데스크톱 애플리케이션에 대한 검색 순서를 사용합니다.
Return Value
함수가 성공하면 반환 값은 모듈에 대한 핸들입니다. 오류가 발생한 경우 반환 값은 .입니다 NULL
.
설명
DLL 함수의 주소를 가져오는 데 사용할 수 있는 GetProcAddress
핸들을 반환합니다. AfxLoadLibrary
를 사용하여 다른 실행 모듈을 매핑할 수도 있습니다.
각 프로세스는 로드된 각 라이브러리 모듈에 대한 참조 수를 유지 관리합니다. 이 참조 수는 호출될 때마다 AfxLoadLibrary
증가하며 호출될 때마다 AfxFreeLibrary
감소됩니다. 참조 횟수가 0에 도달하면, 호출 프로세스의 주소 공간에서 모듈이 매핑 해제되고 핸들이 더 이상 유효하지 않습니다.
애플리케이션이 여러 스레드를 사용하는 AfxLoadLibrary
경우와 AfxFreeLibrary
FreeLibrary
MFC 확장 DLL을 동적으로 로드하는 경우 Win32 함수 LoadLibrary
대신 사용해야 합니다. MFC AfxLoadLibrary
확장 DLL이 로드되고 AfxFreeLibrary
언로드될 때 실행되는 시작 및 종료 코드가 전역 MFC 상태를 손상시키지 않도록 합니다.
애플리케이션에서 사용 AfxLoadLibrary
하려면 DLL 버전의 MFC에 동적으로 연결해야 합니다. 에 Afxdll_.h
대한 AfxLoadLibrary
헤더 파일은 MFC가 애플리케이션에 DLL로 연결된 경우에만 포함됩니다. MFC 확장 DLL을 사용하거나 만들려면 MFC의 DLL 버전에 연결해야 하기 때문에 이 요구 사항은 기본적으로 적용됩니다.
예시
// The following shows how to create a MDI based application
// using a generic CView derived class that is implemented in
// a dynamically loaded MFC Extension DLL.
typedef CRuntimeClass *(*GETDLLVIEW)();
BOOL CUserApp::InitInstance()
{
// Standard Application Wizard generated initialization excluded.
// Register the application's document templates. Document templates
// serve as the connection between documents, frame windows and views
//Load MFC Extension DLL based view class.
m_hViewDll = AfxLoadLibrary(szMyViewDllPath);
if (!m_hViewDll)
{
CString str;
str.Format(_T("Error: Cannot find component %s"), szMyViewDllPath);
AfxMessageBox(str);
return FALSE;
}
GETDLLVIEW GetMyView = (GETDLLVIEW)GetProcAddress(m_hViewDll, "GetMyView");
ASSERT(GetMyView != NULL);
CMultiDocTemplate *pDocTemplate;
pDocTemplate = new CMultiDocTemplate(IDR_NVC_MFC_DLLUserTYPE,
RUNTIME_CLASS(CUserDoc),
RUNTIME_CLASS(CChildFrame), // custom MDI child frame
GetMyView());
if (!pDocTemplate)
return FALSE;
AddDocTemplate(pDocTemplate);
// Standard Application Wizard generated initialization excluded.
return TRUE;
}
int CUserApp::ExitInstance()
{
if (NULL != m_hViewDll)
{
AfxFreeLibrary(m_hViewDll);
m_hViewDll = NULL;
}
return CWinApp::ExitInstance();
}
요구 사항
머리글 afxdll_.h
AfxLoadLibraryEx
AfxLoadLibraryEx
를 사용해서 DLL 모듈을 매핑합니다.
HINSTANCE AFXAPI AfxLoadLibraryEx(LPCTSTR lpFileName, HANDLE hFile, DWORD dwFlags);
매개 변수
lpFileName
모듈의 이름(.DLL 또는 .EXE 파일)이 포함된 null로 끝나는 문자열을 가리킵니다. 지정된 이름은 모듈의 파일 이름입니다.
문자열이 경로를 지정하지만 지정된 디렉터리에 파일이 없으면 함수가 실패합니다.
경로를 지정하지 않고 파일 이름 확장명은 생략하면 기본 확장명 .DLL 추가됩니다. 그러나 파일 이름 문자열에는 모듈 이름에 확장명 없음을 나타내는 후행 지점 문자(.)가 포함될 수 있습니다. 경로가 지정되지 않은 경우 함수는 데스크톱 애플리케이션에 대한 검색 순서를 사용합니다.
hFile
이 매개 변수는 나중에 사용하기 위해 예약되었습니다. NULL
여야 합니다.
dwFlags
모듈을 로드할 때 수행할 작업입니다. 플래그를 지정하지 않으면 이 함수의 동작이 함수와 AfxLoadLibrary
동일합니다. 이 매개 변수의 가능한 값은 설명서에 LoadLibraryEx
설명되어 있습니다.
Return Value
함수가 성공하면 반환 값은 모듈에 대한 핸들입니다. 오류가 발생한 경우 반환 값은 .입니다 NULL
.
설명
AfxLoadLibraryEx
는 DLL 함수의 주소를 가져오는 데 사용할 수 있는 GetProcAddress
핸들을 반환합니다. AfxLoadLibraryEx
를 사용하여 다른 실행 모듈을 매핑할 수도 있습니다.
각 프로세스는 로드된 각 라이브러리 모듈에 대한 참조 수를 유지 관리합니다. 이 참조 수는 호출될 때마다 AfxLoadLibraryEx
증가하며 호출될 때마다 AfxFreeLibrary
감소됩니다. 참조 횟수가 0에 도달하면, 호출 프로세스의 주소 공간에서 모듈이 매핑 해제되고 핸들이 더 이상 유효하지 않습니다.
애플리케이션에서 여러 스레드를 사용하고 AfxLoadLibraryEx
AfxFreeLibrary
MFC 확장 DLL을 동적으로 로드하는 경우 Win32 함수 LoadLibraryEx
FreeLibrary
대신 사용해야 합니다. MFC 확장 DLL이 로드되고 AfxFreeLibrary
언로드될 때 실행되는 시작 및 종료 코드가 전역 MFC 상태를 손상시키지 않도록 합니다AfxLoadLibraryEx
.
애플리케이션에서 사용 AfxLoadLibraryEx
하려면 DLL 버전의 MFC에 동적으로 연결해야 합니다. 에 Afxdll_.h
대한 AfxLoadLibraryEx
헤더 파일은 MFC가 애플리케이션에 DLL로 연결된 경우에만 포함됩니다. MFC 확장 DLL을 사용하거나 만들려면 MFC의 DLL 버전에 연결해야 하기 때문에 이 요구 사항은 기본적으로 적용됩니다.
요구 사항
머리글 afxdll_.h
AfxMenuTearOffManager
전역 분리 메뉴 관리자에 대한 포인터입니다.
구문
CMenuTearOffManager* g_pTearOffMenuManager;
요구 사항
머리글: afxmenutearoffmanager.h
AfxMouseManager
전역 마우스 관리자에 대한 포인터입니다.
구문
CMouseManager* afxMouseManager;
요구 사항
머리글: afxmousemanager.h
AfxRegisterClass
이 함수를 사용하여 MFC를 사용하는 DLL에 창 클래스를 등록합니다.
BOOL AFXAPI AfxRegisterClass(WNDCLASS* lpWndClass);
매개 변수
lpWndClass
등록할 WNDCLASS
창 클래스에 대한 정보를 포함하는 구조체에 대한 포인터입니다. 이 구조에 대한 자세한 내용은 Windows SDK를 참조하세요.
Return Value
TRUE
클래스가 성공적으로 등록되면
설명
이 함수를 사용하는 경우 DLL이 언로드될 때 클래스의 등록이 자동으로 취소됩니다.
비 DLL 빌드 AfxRegisterClass
에서는 애플리케이션에 등록된 클래스가 자동으로 등록 취소되므로 식별자가 Windows 함수 RegisterClass
에 매핑되는 매크로로 정의됩니다. 대신 RegisterClass
사용하는 AfxRegisterClass
경우 애플리케이션과 DLL 모두에서 변경 없이 코드를 사용할 수 있습니다.
예시
// Register your unique class name that you wish to use
WNDCLASS wndcls;
memset(&wndcls, 0, sizeof(WNDCLASS)); // start with NULL defaults
wndcls.style = CS_DBLCLKS | CS_HREDRAW | CS_VREDRAW;
//you can specify your own window procedure
wndcls.lpfnWndProc = ::DefWindowProc;
wndcls.hInstance = AfxGetInstanceHandle();
wndcls.hIcon = LoadIcon(wndcls.hInstance, MAKEINTRESOURCE(IDI_MYICON));
wndcls.hCursor = LoadCursor(wndcls.hInstance, MAKEINTRESOURCE(IDC_ARROW));
wndcls.hbrBackground = (HBRUSH)(COLOR_WINDOW + 1);
wndcls.lpszMenuName = NULL;
// Specify your own class name for using FindWindow later
wndcls.lpszClassName = _T("MyNewClass");
// Register the new class and trace if it fails
if(!AfxRegisterClass(&wndcls))
{
TRACE("Class Registration Failed\n");
}
요구 사항
머리글 afxwin.h
AfxRegisterWndClass
사용자 고유의 창 클래스를 등록할 수 있습니다.
LPCTSTR AFXAPI AfxRegisterWndClass(
UINT nClassStyle,
HCURSOR hCursor = 0,
HBRUSH hbrBackground = 0,
HICON hIcon = 0);
매개 변수
nClassStyle
창 클래스에 대해 비트 OR(|
) 연산자를 사용하여 만든 Windows 클래스 스타일 또는 스타일 조합을 지정합니다. 클래스 스타일 목록은 Windows SDK의 WNDCLASS
구조를 참조하세요. 이 경우 NULL
기본값은 다음과 같이 설정됩니다.
마우스 스타일을 설정하여 사용자가 마우스를
CS_DBLCLKS
두 번 클릭할 때 창 프로시저에 두 번 클릭 메시지를 보냅니다.화살표 커서 스타일을 Windows 표준
IDC_ARROW
으로 설정합니다.배경 브러시를 설정하므로
NULL
창에서 배경이 지워지지 않습니다.아이콘을 표준 물결표 Windows 로고 아이콘으로 설정합니다.
hCursor
창 클래스에서 만든 각 창에 설치할 커서 리소스에 대한 핸들을 지정합니다. 기본값 인 0을 사용하면 표준 IDC_ARROW
커서가 표시됩니다.
hbrBackground
창 클래스에서 만든 각 창에 설치할 브러시 리소스에 대한 핸들을 지정합니다. 기본값 인 0을 사용하는 경우 배경 브러시가 NULL
있으며, 기본적으로 창은 처리하는 WM_ERASEBKGND
동안 해당 배경을 지우지 않습니다.
hIcon
창 클래스에서 만든 각 창에 설치할 아이콘 리소스에 대한 핸들을 지정합니다. 기본값 인 0을 사용하면 표준 물결표 Windows 로고 아이콘이 표시됩니다.
Return Value
클래스 이름을 포함하는 null로 끝나는 문자열입니다. 이 클래스 이름을 멤버 함수 또는 Create
다른 **CWnd-
**파생 클래스에 CWnd
전달하여 창을 만들 수 있습니다. 이름은 Microsoft Foundation 클래스 라이브러리에 의해 생성됩니다.
참고 항목
반환 값은 정적 버퍼에 대한 포인터입니다. 이 문자열을 저장하려면 변수에 CString
할당합니다.
설명
Microsoft Foundation 클래스 라이브러리는 몇 가지 표준 창 클래스를 자동으로 등록합니다. 고유한 창 클래스를 등록하려면 이 함수를 호출합니다.
클래스에 AfxRegisterWndClass
등록된 이름은 매개 변수에만 따라 달라집니다. 동일한 매개 변수를 사용하여 여러 번 호출 AfxRegisterWndClass
하는 경우 첫 번째 호출에서만 클래스를 등록합니다. 나중에 동일한 매개 변수를 사용하여 AfxRegisterWndClass
호출하면 이미 등록된 클래스 이름이 반환됩니다.
각 클래스에 대해 별도의 창 클래스를 가져오는 대신 동일한 매개 변수를 사용하여 여러 CWnd
파생 클래스를 호출 AfxRegisterWndClass
하는 경우 각 클래스는 동일한 창 클래스를 공유합니다. 이 공유는 클래스 스타일을 사용하는 경우 CS_CLASSDC
문제를 일으킬 수 있습니다. 여러 CS_CLASSDC
창 클래스 대신 하나의 창 클래스로 CS_CLASSDC
끝납니다. 해당 클래스를 사용하는 모든 C++ 창은 동일한 DC를 공유합니다. 이 문제를 방지하려면 클래스를 등록하도록 호출 AfxRegisterClass
합니다.
창 클래스 등록 및 함수에 대한 자세한 내용은 기술 참고 TN001: Window 클래스 등록을 AfxRegisterWndClass
참조하세요.
예시
CString strMyClass;
// load stock cursor, brush, and icon for
// my own window class
try
{
strMyClass = AfxRegisterWndClass(
CS_VREDRAW | CS_HREDRAW,
::LoadCursor(NULL, IDC_ARROW),
(HBRUSH)::GetStockObject(WHITE_BRUSH),
::LoadIcon(NULL, IDI_APPLICATION));
}
catch (CResourceException *pEx)
{
AfxMessageBox(_T("Couldn't register class! (Already registered?)"));
pEx->Delete();
}
요구 사항
머리글 afxwin.h
AfxSetPerUserRegistration
애플리케이션이 (HKCU
) 노드에 대한 레지스트리 액세스를 HKEY_CURRENT_USER
리디렉션하는지 여부를 설정합니다.
void AFXAPI AfxSetPerUserRegistration(BOOL bEnable);
매개 변수
bEnable
[in] TRUE
는 레지스트리 정보가 노드로 전달됨을 HKCU
나타냅니다. FALSE
는 애플리케이션이 기본 노드에 레지스트리 정보를 씁니다. 기본 노드는 (HKCR
)입니다 HKEY_CLASSES_ROOT
.
설명
Windows Vista 이전에는 레지스트리에 액세스한 애플리케이션에서 일반적으로 노드를 사용했습니다 HKEY_CLASSES_ROOT
. 그러나 Windows Vista 이상 운영 체제에서는 관리자 권한 모드로 애플리케이션을 실행하여 을 작성 HKCR
해야 합니다.
이 메서드를 사용하면 애플리케이션이 관리자 모드에서 실행하지 않고도 레지스트리를 읽고 쓸 수 있습니다. 레지스트리 액세스를 .로 HKCR
리디렉션하여 작동합니다 HKCU
. 자세한 내용은 Linker Property Pages을 참조하세요.
레지스트리 리디렉션을 사용하도록 설정하면 프레임워크가 액세스를 .로 HKCR
HKEY_CURRENT_USER\Software\Classes
리디렉션합니다. MFC 및 ATL 프레임워크만 리디렉션의 영향을 받습니다.
기본 구현은 아래 HKCR
의 레지스트리에 액세스합니다.
요구 사항
머리글 afxstat_.h
AfxSetResourceHandle
이 함수를 사용하여 애플리케이션의 HINSTANCE
기본 리소스가 로드되는 위치를 결정하는 핸들을 설정합니다.
void AFXAPI AfxSetResourceHandle(HINSTANCE hInstResource);
매개 변수
hInstResource
애플리케이션의 리소스가 로드되는 .EXE 또는 DLL 파일에 대한 인스턴스 또는 모듈 핸들입니다.
예시
// This code is taken from CMyApp::InitInstance
HINSTANCE hRes = NULL;
hRes = LoadLibrary(_T("Resource.dll"));
if (hRes)
AfxSetResourceHandle(hRes);
요구 사항
머리글 afxwin.h
AfxShellManager
전역 셸 관리자에 대한 포인터입니다.
구문
CShellManager* afxShellManager;
요구 사항
머리글: afxshellmanager.h
AfxSocketInit
재정의에서 CWinApp::InitInstance
이 함수를 호출하여 Windows 소켓을 초기화합니다.
BOOL AfxSocketInit(WSADATA* lpwsaData = NULL);
매개 변수
lpwsaData
구조체에 대한 포인터입니다 WSADATA
. lpwsaData
같지 NULL
않으면 구조체의 WSADATA
주소가 호출에 WSAStartup
의해 채워집니다. 또한 이 함수는 애플리케이션이 WSACleanup
종료되기 전에 호출되도록 합니다.
Return Value
함수가 성공하면 0이 아니고 그렇지 않으면 0입니다.
설명
정적으로 연결된 MFC 애플리케이션의 보조 스레드에서 MFC 소켓을 사용하는 경우 소켓을 사용하여 소켓 라이브러리를 초기화하는 각 스레드에서 호출 AfxSocketInit
해야 합니다. 기본적으로 AfxSocketInit
기본 스레드에서만 호출됩니다.
요구 사항
머리글 afxsock.h
AfxUserToolsManager
전역 사용자 도구 관리자에 대한 포인터입니다.
구문
CUserToolsManager* afxUserToolsManager;
요구 사항
머리글: afxusertoolsmanager.h
AfxWinInit
이 함수는 MFC를 초기화하기 위해 GUI 기반 애플리케이션 초기화의 CWinApp
일부로 MFC 제공 WinMain
함수에 의해 호출됩니다.
BOOL AFXAPI AfxWinInit(
HINSTANCE hInstance,
HINSTANCE hPrevInstance,
LPTSTR lpCmdLine,
int nCmdShow);
매개 변수
hInstance
현재 실행 중인 모듈의 핸들입니다.
hPrevInstance
애플리케이션의 이전 인스턴스에 대한 핸들입니다. Win32 기반 애플리케이션의 경우 이 매개 변수는 항상 NULL
.
lpCmdLine
애플리케이션의 명령줄을 지정하는 null로 끝나는 문자열을 가리킵니다.
nCmdShow
GUI 애플리케이션의 주 창을 표시하는 방법을 지정합니다.
설명
MFC 제공 WinMain
함수를 사용하지 않는 콘솔 애플리케이션의 경우 MFC를 초기화하기 위해 직접 호출 AfxWinInit
해야 합니다.
자신을 호출 AfxWinInit
하는 경우 클래스의 CWinApp
인스턴스를 선언해야 합니다. 콘솔 애플리케이션의 경우 고유한 클래스 CWinApp
를 파생하지 않고 대신 직접 인스턴스 CWinApp
를 사용하도록 선택할 수 있습니다. 이 기술은 애플리케이션의 모든 기능을 구현에 그대로 두기로 결정한 경우에 적합합니다 main
.
참고 항목
어셈블리에 대한 활성화 컨텍스트를 만들 때 MFC는 사용자 모듈에서 제공하는 매니페스트 리소스를 사용합니다. 활성화 컨텍스트는 AfxWinInit
에서 만듭니다. 자세한 내용은 MFC 모듈 상태의 활성화 컨텍스트 지원을 참조하세요.
예시
#include <afx.h>
#include <afxdb.h>
int _tmain(int /*argc*/, TCHAR * /*argv[]*/, TCHAR * /*envp[]*/)
{
int nRetCode = 0;
// initialize MFC and print and error on failure
if (!AfxWinInit(::GetModuleHandle(NULL), NULL, ::GetCommandLine(), 0))
{
// TODO: change error code to suit your needs
_tprintf(_T("Fatal Error: MFC initialization failed\n"));
nRetCode = 1;
}
else
{
// try to connect to an ODBC database that doesn't exist
// (this wouldn't work at all without initializing MFC)
CDatabase db;
try
{
db.Open(_T("This Databsae Doesn't Exist"));
// we shouldn't realistically get here
_tprintf_s(_T("Successful!\n")
_T("Closing ...\n"));
db.Close();
_tprintf_s(_T("Closed!"));
}
catch (CDBException *pEx)
{
// we got an exception! print an error message
// (this wouldn't work without initializing MFC)
TCHAR sz[1024];
_tprintf_s(_T("Error: "));
if (pEx->GetErrorMessage(sz, 1024))
_tprintf_s(sz);
else
_tprintf_s(_T("No error message was available"));
_tprintf_s(_T("\n"));
pEx->Delete();
nRetCode = 1;
}
}
return nRetCode;
}
요구 사항
머리글 afxwin.h
참고 항목
매크로 및 전역
CWinApp
수업
CContextMenuManager
클래스
CWnd
수업
CFrameWndEx
수업
CMFCToolBar
수업
CKeyboardManager
클래스
CMenuTearOffManager
수업
CMouseManager
클래스
CShellManager
수업
CUserToolsManager
클래스