LoadLibrary と AfxLoadLibrary
プロセスに DLL を明示的にリンクする場合は、LoadLibrary (または AfxLoadLibrary) を呼び出します。 この関数が正常終了した場合、呼び出し元プロセスのアドレス空間に指定された DLL が割り当てられ、DLL へのハンドルが返されます。このハンドルは、GetProcAddress や FreeLibrary など、明示的リンクに必要な他の関数で使用できます。
LoadLibrary は、暗黙リンクと同じ検索シーケンスで DLL を探します。 システムが DLL を見つけられない場合、またはエントリ ポイント関数が FALSE を返した場合、LoadLibrary は NULL を返します。 LoadLibrary への呼び出しで指定される DLL モジュールが呼び出し元プロセスのアドレス空間に既に割り当てられている場合、この関数は DLL のハンドルを返し、モジュールの参照カウントをインクリメントします。
DLL にエントリ ポイント関数が含まれる場合、オペレーティング システムは、LoadLibrary を呼び出したスレッドのコンテキスト内でその関数を呼び出します。 LoadLibrary の前回の呼び出しに対応する FreeLibrary 関数呼び出しが行われていないために、DLL が既にプロセスにアタッチされている場合は、エントリ ポイント関数は呼び出されません。
拡張 DLL を読み込む MFC アプリケーションでは、LoadLibrary の代わりに AfxLoadLibrary を使用することをお勧めします。 LoadLibrary を呼び出す前に、AfxLoadLibrary でスレッド同期を処理します。 AfxLoadLibrary のインターフェイス (関数プロトタイプ) は、LoadLibrary と同じです。
Windows が DLL を読み込むことができない場合は、プロセスでエラーからの回復を試みることができます。 たとえば、プロセスがユーザーにエラーを通知して、ユーザーに DLL への別のパスを指定するよう要求できます。
セキュリティに関するメモ |
---|
Windows NT 4、Windows 2000、または Windows XP (SP1 以前) でコードを実行する場合は、必ず DLL の完全パス名を指定してください。 これらのオペレーティング システムでファイルが読み込まれると、最初に現在のディレクトリが検索されます。 ファイルのパスを指定していないと、目的のものでないファイルが読み込まれる場合があります。 |