Dica do SistemaEste artigo aplica-se a um sistema operativo diferente do que está a utilizar. Foi desactivado o conteúdo do artigo, que pode não ser relevante para si.
Quando criar um projecto ATL EXE utilizando o AppWizard, a caixa de verificação suporte MFC está desactivada. Este artigo explica como adicionar suporte MFC a um projecto ATL EXE. Este artigo também explica como adicionar suporte MFC a um projecto ATL DLL se falhar inicialmente seleccione a caixa de verificação "suporte MFC" no AppWizard.
Adicione o seguinte # include directivas para StdAfx.h antes para incluindo Atlbase.h:
#include <afxwin.h> // MFC core and standard components
#include <afxext.h> // MFC extensions
#include <afxdisp.h> // MFC Automation extensions
Alterar definições de projecto para utilizar o MFC. Caixa de diálogo Definições do Project , clique no separador Geral e altere a definição na caixa de listagem " Microsoft Foundation Classes " para MFC.
Adicionar uma classe derivada de CWinApp e declarar uma variável global desse tipo da seguinte forma:
class CMyApp : public CWinApp
{
public:
virtual BOOL InitInstance();
virtual int ExitInstance();
protected:
BOOL m_bRun;
};
Substituir a função _tWinMain com o seguinte código InitInstance e ExitInstance:
BOOL CMyApp::InitInstance()
{
// Initialize OLE libraries.
if (!AfxOleInit())
{
AfxMessageBox(_T("OLE Initialization Failed!"));
return FALSE;
}
// Initialize CcomModule.
_Module.Init(ObjectMap, m_hInstance);
_Module.dwThreadID = GetCurrentThreadId();
// Check command line arguments.
TCHAR szTokens[] = _T("-/");
m_bRun = TRUE;
LPCTSTR lpszToken = FindOneOf(m_lpCmdLine, szTokens);
while (lpszToken != NULL)
{
// Register ATL and MFC class factories.
if (lstrcmpi(lpszToken, _T("Embedding"))==0 ||
lstrcmpi(lpszToken, _T("Automation"))==0)
{
AfxOleSetUserCtrl(FALSE);
break;
}
// Unregister servers.
// There is no unregistration code for MFC
// servers. Refer to <WWLINK TYPE="ARTICLE" VALUE="Q186212">Q186212</WWLINK> "How To Unregister MFC
// Automation Servers" for adding unregistration
// code.
else if (lstrcmpi(lpszToken, _T("UnregServer"))==0)
{
VERIFY(SUCCEEDED(_Module.UpdateRegistryFromResource(IDR_ServerS2B, FALSE)));
//Replace IDR_ServerS2B with your project specific resource ID for the registry script resource
VERIFY(SUCCEEDED(_Module.UnregisterServer(TRUE)));
m_bRun = FALSE;
break;
}
// Register ATL and MFC objects in the registry.
else if (lstrcmpi(lpszToken, _T("RegServer"))==0)
{
VERIFY(SUCCEEDED(_Module.UpdateRegistryFromResource(IDR_ServerS2B, TRUE)));
VERIFY(SUCCEEDED(_Module.RegisterServer(TRUE)));
COleObjectFactory::UpdateRegistryAll();
m_bRun = FALSE;
break;
}
lpszToken = FindOneOf(lpszToken, szTokens);
}
if (m_bRun)
{
// Comment out the next line if not using VC 6-generated
// code.
_Module.StartMonitor();
VERIFY(SUCCEEDED(_Module.RegisterClassObjects(CLSCTX_LOCAL_SERVER, REGCLS_MULTIPLEUSE)));
VERIFY(COleObjectFactory::RegisterAll());
// To run the EXE standalone, you need to create a window
// and assign the CWnd* to m_pMainWnd.
LPCTSTR szClass = AfxRegisterWndClass(NULL);
m_pMainWnd = new CWnd;
m_pMainWnd->CreateEx(0, szClass, _T("SomeName"), 0, CRect(0, 0, 0, 0), NULL, 1234);
}
return TRUE;
}
int CMyApp::ExitInstance()
{
// MFC's class factories registration is
// automatically revoked by MFC itself.
if (m_bRun)
{
_Module.RevokeClassObjects();
Sleep(dwPause); //wait for any threads to finish
}
_Module.Term();
return 0;
}
Para Unicode cria, certifique-se que o ponto de entrada está definido para wWinMainCRTStartup na categoria de saída do campo de ligação na caixa de diálogo Definições do Project . Para obter mais informações, clique no número de artigo que se segue para visualizar o artigo na Microsoft Knowledge Base:
125750
(http://support.microsoft.com/kb/125750/
)
Recebe uma mensagem de erro "não resolvido símbolo externo _WinMain@16" quando tenta criar uma aplicação MFC com suporte de Unicode no Visual C++
Adicione a seguinte linha de código o início de cada função de membro de uma interface COM, procedimento de janela e função exportada:
AFX_MANAGE_STATE(AfxGetAppModuleState());
para obter mais informações sobre como AFX_MANAGE_STATE, consulte a documentação online VC ++.
Para mais informações sobre como adicionar suporte MFC a um projecto ATL COM AppWizard, consulte o seguinte artigo na base de dados de conhecimento da Microsoft:
181505
(http://support.microsoft.com/kb/181505/EN-US/
)
PROBLEMA: ATL COM AppWizard não oferecer suporte MFC .exe
Mova o código de DllMain AppWizard geradas DLL_PROCESS_ATTACH e DLL_PROCESS_DETACH o CMyApp InitInstance e ExitInstance e remover o DllMain da seguinte forma:
BOOL CMyApp::InitInstance()
{
_Module.Init(ObjectMap, m_hInstance);
return CWinApp::InitInstance();
}
int CMyApp::ExitInstance()
{
// MFC's class factories registration is
// automatically revoked by MFC itself.
if (m_bRun)
_Module.RevokeClassObjects();
Adicione a seguinte linha de código o início de cada função de membro de uma interface COM, procedimento de janela e função exportada:
AFX_MANAGE_STATE(AfxGetStaticModuleState());
Para obter mais informações, clique no número de artigo que se segue para visualizar o artigo na Microsoft Knowledge Base:
140850
(http://support.microsoft.com/kb/140850/
)
Como exportar correctamente funções utilizando biblioteca partilhada de MFC
NOTA: Para todas as versões de edição, certifique-se de que a definição de pré-processador _ATL_MIN_CRT foi removida. Pode encontrar estas definições na categoria de pré-processador do separador C/C ++ na caixa de diálogo Definições do Project .
Quando adicionar uma classe derivada de uma MFC classe utilizando ClassWizard para um EXE ATL projecto ou a um projecto ATL DLL sem "MFC Support", o compilador emitirá um erro de C2504.
IMPORTANTE: Este artigo foi traduzido por um sistema de tradução automática (também designado por Machine translation ou MT), não tendo sido portanto revisto ou traduzido por humanos. A Microsoft tem artigos traduzidos por aplicações (MT) e artigos traduzidos por tradutores profissionais. O objectivo é simples: oferecer em Português a totalidade dos artigos existentes na base de dados do suporte. Sabemos no entanto que a tradução automática não é sempre perfeita. Esta pode conter erros de vocabulário, sintaxe ou gramática? erros semelhantes aos que um estrangeiro realiza ao falar em Português. A Microsoft não é responsável por incoerências, erros ou estragos realizados na sequência da utilização dos artigos MT por parte dos nossos clientes. A Microsoft realiza actualizações frequentes ao software de tradução automática (MT). Obrigado.
Clique aqui para ver a versão em Inglês deste artigo: 173974
(http://support.microsoft.com/kb/173974/en-us/
)
Qual foi o esforço que despendeu pessoalmente para utilizar este artigo?
Muito baixo
Baixo
Moderado
Elevado
Muito elevado
Diga-nos porquê e o que podemos fazer para melhorar estas informações
Obrigado! Os seus comentários são utilizados para ajudar-nos a melhorar o conteúdo do nosso suporte. Para obter mais opções de assistência, visite a Home Page de Ajuda e Suporte.