
No.5ベストアンサー
- 回答日時:
Debug Help (dbghelp)はVS6の頃にはまだ存在せず、VS.NETになって新たに登場したものですので、VS6ですと見つかりません。
Debug HelpはImage Help (imagehlp)の後継で、例示プログラム中で使用している定義の範囲ですとImage Helpのヘッダファイル(imagehlp.h)でも同様に使用できますので、dbghelp.hのかわりにimagehlp.hを参照してください。
No.4
- 回答日時:
調べたところ、dbghelp.dllを使用すると「めちゃめちゃ面倒」は「少々面倒」くらいで済むようです。
エラーチェックは適当ですが、ひとまず動作するCのプログラムを下記するので、適当にVBコードに変更してください。(すみません最初からVBのコードでなくて。)
#include <windows.h>
#include <winnt.h>
#include <dbghelp.h>
#include <stdio.h>
#include <string.h>
int main(int argc, char** argv)
{
char* pszImageName = argv[argc - 1];
HANDLE hProcess = GetCurrentProcess();
SymInitialize(hProcess, "", FALSE);
DWORD dwBase = SymLoadModule(hProcess, NULL, pszImageName, NULL, 0, 0);
if (dwBase == 0) {
printf("SymLoadModule failed\n");
return 1;
}
DWORD dwSize;
PVOID pv = ImageDirectoryEntryToData((PVOID)(DWORD_PTR)dwBase, TRUE, IMAGE_DIRECTORY_ENTRY_EXPORT, &dwSize);
if (pv == NULL) {
printf("ImageDirectoryEntryToData failed\n");
return 2;
}
PIMAGE_EXPORT_DIRECTORY pImageExportDirectory = (PIMAGE_EXPORT_DIRECTORY)pv;
char** ppFunctionName = (char**)(DWORD_PTR)(pImageExportDirectory->AddressOfNames + dwBase);
DWORD dw;
for (dw = 0; dw < pImageExportDirectory->NumberOfNames; ++dw) {
printf("%3u: %s\n", dw, *ppFunctionName + dwBase);
++ppFunctionName;
}
SymUnloadModule(hProcess, dwBase);
return 0;
}
この回答への補足
こんにちは。VCで試してみたのですが、dbghelp.hが見つからないようです。こちらではVS6で試したのですが、Program Files\VC98以下のフォルダにはないようです。Googleで検索すると、http://dotnet.di.unipi.it/Content/sscli/docs/dox …
が引っかかったので、これをdbghelp.hファイルとして行番号を抜いてみて使用してみたのですが、うまくコンパイルできませんでした。dbghelp.hはどこかから入手することができるのでしょうか?手数をかけてすみません。
どうもありがとうございます。このコードから拝見するに、指定されたファイル中のエクスポートされている関数をpImageExportDirectory変数から取り出してリストアップしているような感じですよね。そうすると命令群を取り出すのにはImageDirectoryEntryToData命令を使用する必要があるといった感じでしょうか?各命令の意味を調べてみます。
No.3
- 回答日時:
#2>プログラムコードから調べる方法を探しています
最悪、プログラムからツールを実行し、ツールの出力をプログラムから取り込む(バカげてる?)こともできるかと思いますが。
No.1
- 回答日時:
何か手軽なライブラリがあるといいんですけどね・・・
私は
「An In-Depth Look into the Win32 Portable Executable File Format」
http://msdn.microsoft.com/msdnmag/issues/02/02/P …
の記述に沿って、DLLファイルの中身をバイナリデータとしていちいち調べて使っていますが、めちゃめちゃ面倒です。
ありがとうございます。うーむ。英語ドキュメントですね。でも少し目を通して見る必要がありそうな感じですね。Dependency Walker等はこのような方法で情報を取得しているのかも知れませんね。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ネットワークにつながっている...
-
c++ 文字列を入力して、一文字...
-
2曲同時再生するにはどうした...
-
コマンドラインからの入力で
-
文字列から空白を取り除きたい...
-
配列をnビットシフトする
-
「ポインタのポインタ」を使っ...
-
間接参照のレベルが異なっています
-
テキストデータをそのままバイ...
-
C言語のfor文です。 繰り返しの...
-
Linuxでフォルダ内全ファイル名...
-
全角文字を含んだ文字の並びを...
-
atoi( ) の反対をやりたい
-
ADOレコードセット操作(Forルー...
-
プログラム
-
'const char *' 型は 'char *' ...
-
fgetsなどのときのstdinのバッ...
-
char型+char型ってint型? if...
-
boost::pointee
-
pingの結果を取得する方法
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
構造体の各メンバにfor文からア...
-
fgetsなどのときのstdinのバッ...
-
文字列から空白を取り除きたい...
-
C言語のfor文です。 繰り返しの...
-
CStringをwchar_tに変換したい
-
間接参照のレベルが異なっています
-
c++ 文字列を入力して、一文字...
-
C言語の入力した文字を反転させ...
-
charからLPTSTRへの変換方法
-
ネットワークにつながっている...
-
'const char *' 型は 'char *' ...
-
テキストデータをそのままバイ...
-
c言語でユーザ関数を利用して入...
-
atoi( ) の反対をやりたい
-
間接操作のレベルとは
-
-'0'の意味について
-
double型の値をchar配列に変換...
-
Linuxでフォルダ内全ファイル名...
-
配列をnビットシフトする
-
型変換
おすすめ情報