AfxWinInit
この関数は、 GUI ベースのアプリケーションの CWinApp の初期化の一部として WinMain の MFC 版関数によって、 MFC を初期化するために呼び出されます。
BOOL AFXAPI AfxWinInit(
HINSTANCE hInstance,
HINSTANCE hPrevInstance,
LPTSTR lpCmdLine,
int nCmdShow
);
パラメーター
hInstance
現在実行中のモジュール ハンドル。hPrevInstance
アプリケーションの前のインスタンスへのハンドル。Win32 ベースのアプリケーションでは、このパラメーターは NULL常にです。lpCmdLine
アプリケーションのコマンド ラインを指定する終了文字列へのポインター。nCmdShow
GUI アプリケーションのメイン ウィンドウがどのように表示されるかを指定します。
解説
WinMain の MFC 版関数を使用しないコンソール アプリケーション用に、 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