
すみません、何度もDLLの事で質問しています。
おかげさまでファイルマッピングを利用してメモリを共有することが
できました。ありがとうございました。
【今回の質問】
DLLが最初に呼ばれた時と、最後にアンロードされた時って、
DLL側で認識可能なのでしょうか?
最初に呼ばれたときにメモリをアロケートし、最後に解放したいのですが、
呼び元の処理も不特定多数から呼ばれるので、
初期処理・終了処理のタイミングが取れないらしいのです。
色々調べていたら何回ロードされているか、参照カウントというのを
どこかで持っているらしいのですが、これが使えないでしょうか。
また、今はライブラリをリンクしているので、
LoadLibrary、FreeLibraryは使用していませんが、
その場合でも同じように参照カウントで管理されるのですか?
申し訳ありませんが、ご教示ください。
よろしくお願いいたします。
No.1ベストアンサー
- 回答日時:
マルチスレッドのことはよく知りません。
LoadLibrary、FreeLibraryのことを書きます。
不用に何度もロードされた場合、そのロード回数をDLL内で知る方法は分からないです。
最初に呼び出された時だけ、DLL内のDllMainでDLL_PROCESS_ATTACHを受け取れます。
2度目以降の不要な呼び出しでは、内部でカウントされているらしいけど、その場合はDLL内のDllMainでDLL_PROCESS_ATTACHを受け取れません。
最後のアンロードを認識も、DLL内のDllMainでDLL_PROCESS_DETACHを受け取ることによって知ることができます。
内部で不要なロードのカウントがあった場合はDLL_PROCESS_DETACHを受け取れす、内部のカウントは1つ減らされるらしいです。
この回答への補足
今回はクラスをエクスポートしたため、この方法の使い方がわかりませんでした。
このクラスをインポートされた時に、どこかでDLL_PROCESS_ATTACHが
発生していると思うのですが・・・。
また別の形で質問させて頂きます。ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
プログラム上のCPU稼働率低減に...
-
C#で書かれたプログラムをバッ...
-
VC++2010 GDIオブジェクトの解...
-
異なるプログラミング言語を連...
-
Excel VBAにて、2GB超の点群デ...
-
#ifdefはどうやって使う?
-
Excel(VBA)でSetTimer関数を使...
-
win10で、正確な待ち時間の作り方
-
DoEvents関数って何?
-
PIC mainループについて
-
テキスト処理の速度の速い言語
-
Excelでのセル内容の高速消去方法
-
【C言語 数独】 C言語で9×9の数...
-
Excel VBA での処理時間計測結...
-
関数呼び出しの処理
-
wavelet変換のソフト
-
非同期プログラミングは必ずマ...
-
If Not c Is Nothing Then ~延...
-
SQLの速度をあげるには・・・
-
大学のプログラミングの課題に...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
win10で、正確な待ち時間の作り方
-
Excelでのセル内容の高速消去方法
-
Excel VBAにて、2GB超の点群デ...
-
小数点を含む数値かどうか判断...
-
プログラム上のCPU稼働率低減に...
-
SQLの速度をあげるには・・・
-
DoEvents関数って何?
-
基本情報技術者試験詳しい方へ...
-
実行時のCPU使用率を増やしたい
-
VC++2010 GDIオブジェクトの解...
-
C言語 時刻差分の算出方法
-
ナップザック問題?をエクセル...
-
Excel(VBA)でSetTimer関数を使...
-
エクセルVBA 時間抜けの取得
-
VBでの簡易電卓の作成(減算方...
-
ノットイコールを教えて下さい
-
If Not c Is Nothing Then ~延...
-
Excel VBA データ削除の高速化
-
絶対パスの取得について
-
テキスト処理の速度の速い言語
おすすめ情報