AFX_MODULE_STATE
AFX_MODULE_STATE
1: // AFX_MODULE_STATE (global data for a module)
2: class AFX_MODULE_STATE : public CNoTrackObject
3: {
4: public:
5: #ifdef _AFXDLL
6: AFX_MODULE_STATE(BOOL bDLL, WNDPROC pfnAfxWndProc, DWORD dwVersion,
7: BOOL bSystem = FALSE);
8: #else
9: explicit AFX_MODULE_STATE(BOOL bDLL);
10: #endif
11: ~AFX_MODULE_STATE();
12:
13: CWinApp* m_pCurrentWinApp;
14: HINSTANCE m_hCurrentInstanceHandle;
15: HINSTANCE m_hCurrentResourceHandle;
16: LPCTSTR m_lpszCurrentAppName;
17: BYTE m_bDLL; // TRUE if module is a DLL, FALSE if it is an EXE
18: BYTE m_bSystem; // TRUE if module is a "system" module, FALSE if not
19: BYTE m_bReserved[2]; // padding
20:
21: DWORD m_fRegisteredClasses; // flags for registered window classes
22:
23: // runtime class data
24: #ifdef _AFXDLL
25: CRuntimeClass* m_pClassInit;
26: #endif
27: CTypedSimpleList
m_classList;
28:
29: // OLE object factories
30: #ifndef _AFX_NO_OLE_SUPPORT
31: #ifdef _AFXDLL
32: COleObjectFactory* m_pFactoryInit;
33: #endif
34: CTypedSimpleList
m_factoryList;
35: #endif
36: // number of locked OLE objects
37: long m_nObjectCount;
38: BOOL m_bUserCtrl;
39:
40: // AfxRegisterClass and AfxRegisterWndClass data
41:
42: CString m_strUnregisterList;
43:
44: #ifdef _AFXDLL
45: WNDPROC m_pfnAfxWndProc;
46: DWORD m_dwVersion; // version that module linked against
47: #endif
48:
49: // variables related to a given process in a module
50: // (used to be AFX_MODULE_PROCESS_STATE)
51: void (PASCAL *m_pfnFilterToolTipMessage)(MSG*, CWnd*);
52:
53: #ifdef _AFXDLL
54: // CDynLinkLibrary objects (for resource chain)
55: CTypedSimpleList
m_libraryList;
56:
57: // special case for MFCXXLLL.DLL (localized MFC resources)
58: HINSTANCE m_appLangDLL;
59: #endif
60:
61: #ifndef _AFX_NO_OCC_SUPPORT
62: // OLE control container manager
63: COccManager* m_pOccManager;
64: // locked OLE controls
65: CTypedSimpleList
m_lockList;
66: #endif
67:
68: #ifndef _AFX_NO_DAO_SUPPORT
69: _AFX_DAO_STATE* m_pDaoState;
70: #endif
71:
72: #ifndef _AFX_NO_OLE_SUPPORT
73: // Type library caches
74: CTypeLibCache m_typeLibCache;
75: CTypeLibCacheMap* m_pTypeLibCacheMap;
76: #endif
77:
78: // define thread local portions of module state
79: CThreadLocal
m_thread;
80:
81: //Fusion: declare pointer to array of pointers to isolation aware dll wrappers (ex: comctl32).
82: CDllIsolationWrapperBase** m_pDllIsolationWrappers;
83: //Defaults to TRUE. When FALSE - MFC will not activate context in AFX_MAINTAIN_STATE2 (used by AFX_MANAGE_STATE).
84: BOOL m_bSetAmbientActCtx;
85: //Handle of the module context.
86: HANDLE m_hActCtx;
87: void CreateActivationContext();
88:
89: // bool indicating the return value of InitNetworkAddressControl() (from shell32.dll)
90: BOOL m_bInitNetworkAddressControl;
91: // bool indicating whether or not InitNetworkAddressControl() (from shell32.dll) have been called for CNetAddressCtrl
92: BOOL m_bInitNetworkAddressControlCalled;
93: };
AFX_MODULE_STATE::AFX_MODULE_STATE
1: /////////////////////////////////////////////////////////////////////////////
2: // AFX_MODULE_STATE implementation
3:
4: #ifdef _AFXDLL
5: AFX_MODULE_STATE::AFX_MODULE_STATE(BOOL bDLL, WNDPROC pfnAfxWndProc,
6: DWORD dwVersion, BOOL bSystem)
7: #else
8: AFX_MODULE_STATE::AFX_MODULE_STATE(BOOL bDLL)
9: #endif
10: {
11: #ifndef _AFX_NO_OLE_SUPPORT
12: m_factoryList.Construct(offsetof(COleObjectFactory, m_pNextFactory));
13: #endif
14: m_classList.Construct(offsetof(CRuntimeClass, m_pNextClass));
15:
16: m_fRegisteredClasses = 0;
17: m_bDLL = (BYTE)bDLL;
18: #ifdef _AFXDLL
19: m_pfnAfxWndProc = pfnAfxWndProc;
20: m_dwVersion = dwVersion;
21: m_bSystem = (BYTE)bSystem;
22: #endif
23: BOOL bEnable = TRUE;
24: TRY
25: {
26: //Preallocate the registered classes string, but CRT memory leak report is
27: //called before the string frees memory, so need to disable tracking.
28: bEnable = AfxEnableMemoryTracking(FALSE);
29: m_strUnregisterList.Preallocate(4096);
30: AfxEnableMemoryTracking(bEnable);
31: }
32: CATCH(CMemoryException, e)
33: {
34: AfxEnableMemoryTracking(bEnable);
35: DELETE_EXCEPTION(e);
36: }
37: END_CATCH
38: // app starts out in "user control"
39: m_bUserCtrl = TRUE;
40:
41: #ifndef _AFX_NO_OCC_SUPPORT
42: m_lockList.Construct(offsetof(COleControlLock, m_pNextLock));
43: #endif
44: #ifdef _AFXDLL
45: m_libraryList.Construct(offsetof(CDynLinkLibrary, m_pNextDLL));
46: #endif
47:
48:
49: bEnable = AfxEnableMemoryTracking(FALSE);
50: //Fusion: allocate dll wrappers array.
51: m_pDllIsolationWrappers = new CDllIsolationWrapperBase*[_AFX_ISOLATION_WRAPPER_ARRAY_SIZE];
52: #ifndef _AFX_NO_AFXCMN_SUPPORT
53: m_pDllIsolationWrappers[_AFX_COMCTL32_ISOLATION_WRAPPER_INDEX] = new CComCtlWrapper;
54: #endif
55: m_pDllIsolationWrappers[_AFX_COMMDLG_ISOLATION_WRAPPER_INDEX] = new CCommDlgWrapper;
56: m_pDllIsolationWrappers[_AFX_SHELL_ISOLATION_WRAPPER_INDEX] = new CShellWrapper;
57: AfxEnableMemoryTracking(bEnable);
58: m_bSetAmbientActCtx = TRUE;
59: m_hActCtx = NULL;
60: m_bInitNetworkAddressControl = FALSE;
61: m_bInitNetworkAddressControlCalled = FALSE;
62: }
The Common Controls library is now isolated within MFC, allowing different modules (such as user DLLs) to use different versions of the Common Controls library by specifying the version in their manifests.
An MFC application (or user code called by MFC) makes calls to Common Controls library APIs through wrapper functions named AfxFunctionName, where FunctionName is the name of a Common Controls API. Those wrapper functions are defined in afxcomctl32.h and afxcomctl32.inl.
You can use the AFX_COMCTL32_IF_EXISTS and AFX_COMCTL32_IF_EXISTS2 macros (defined in afxcomctl32.h) to determine whether the Common Controls library implements a certain API instead of calling GetProcAddress.
Technically, you make calls to Common Controls Library APIs through a wrapper class, CComCtlWrapper (defined in afxcomctl32.h). CComCtlWrapper is also responsible for the loading and unloading of comctl32.dll. The MFC Module State contains a pointer to an instance of CComCtlWrapper. You can access the wrapper class using the afxComCtlWrapper macro.
Note that calling Common Controls API directly (not using the MFC wrapper functions) from an MFC application or user DLL will work in most cases, because the MFC application or user DLL is bound to the Common Controls library it requested in its manifest). However, the MFC code itself has to use the wrappers, because MFC code might be called from user DLLs with different Common Controls library versions.
WinSxS
WinSxS는 Windows 디렉터리의 다음 중요한 디렉터리로, 안에 있는 파일은 삭제할 수 없습니다.
WinSxS에는 매우 많은 중요한 구성 요소가 있고 버전도 번잡합니다. Windows의 정상적인 운행을 보장하기 위해서 이 파일들이 하나도 없어서는 안 됩니다.이 파일들은 mscorwks를 지탱하고 있다.dll, 그것들이 없으면 mscorwks도 불러올 수 없습니다.강제로 삭제한 후에는 보안 모드로만 Windows에 들어갈 수 있고 Windows도 폐기될 수 있습니다.
WinSxS에 대한 Microsoft의 지침은 다음과 같습니다.
COM 및 공유 DLL 격리 지원
Windows XP/Vista는 Windows 디렉토리에 WinSxS(Windows Side-by-side)라는 폴더를 제공합니다.시스템은 이 폴더를 사용하여 각 버전의 Windows XP 구성 요소를 저장하며, 동적 링크 라이브러리(Dynamic Link Libraries, DLL)로 인한 구성 문제(DLL hell)를 줄입니다.구성 요소의 여러 버전이 이 폴더에 저장되어 있습니다.Windows XP에서 Win32를 사용할 수 있습니까?API 구성 요소 및 애플리케이션은 테스트 시 사용하는 버전과 정확히 일치하는 Microsoft 구성 요소 버전을 사용하며 다른 프로그램이나 운영 체제 업그레이드의 영향을 받지 않습니다.Windows XP는 응용 프로그램 구성에 대한 메타데이터(예: COM 클래스, 인터페이스 및 유형 라이브러리)를 저장하는 XML 파일을 통해 이러한 기능을 수행합니다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
제한된 크기의 디렉토리를 만드는 방법오늘 저는 장치에 공간이 없을 때 백업 중에 응용 프로그램이 어떻게 작동하는지 테스트(및 수정)하는 작업이 있습니다. 결과적으로 "남은 공간 없음"오류로 백업이 실패하면 새 파일이 없어야 합니다. 지금까지 문제를 재...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.