C++言語で書かれたプログラムの実行ファイルが50個ほど
あり(それぞれ50MB程度)、ある関数を修正した場合に
どの実行ファイルに影響があるか調べたいのですが、
ソースコードを追って依存関係を調べるのは現実的ではないため
実行ファイルの中にその関数名が含まれるかどうかで
判断しようと思っております。
ためしにFTPでパソコン上に転送して、バイナリエディタで表示し
使用している関数名が文字列として含まれていることは
確認できましたが、毎回全ファイルをFTP転送するのは避けたいので、
同様の調査をUNIXマシン上で行いたいのですが、
バイナリファイルから文字列を検索するコマンドは
ありますでしょうか?
OSは SUN OS5.8です。
宜しくお願いします。
No.2ベストアンサー
- 回答日時:
状況によるんだけど,
・何も考えず grep (存在するかどうかくらいは出るんじゃないかな)
・strings + (必要なら c++filt) + grep (普通)
・nm + (必要なら c++filt) + grep (オブジェクトファイルなどに限定)
くらいは思い付くかな. c++filt はなくてもいいけど, あった方が「出力をよみやすい」と思います.
この回答への補足
grep だと strings と同様に検出できず、fgrepでは検出できました。grep系はテキストファイルを前提にしているとはずなのでバイナリファイルだと動作が保証されなさそうです。fgrepでも必ず検出できるかどうか不安なので、もっと確実な方法を考えたいと思います。
文字列検索を自作する手もあるのですが、それ自体にバグがあったら意味がないので、出来れば一般に使われている実績のあるものにしたいです。一般に使われているものならばバグもほとんどないとみなせますし、万一のときでも、言い訳できますから^^;
No.7
- 回答日時:
nm -C
なんてものがあるのですね。
勉強になりました。
ところで、少し気になったのですが
対象の関数が、関数ポインタに代入されていたりすると
思わぬところで実行されていたりすると思うので
そういう可能性があるかなど、
対象の関数の性質は抑えておいた方がいいかもしれませんね。
この回答への補足
関数ポインタのことは見落としていました。
開発メンバーが関数ポインタを使えるほどスキルが高くないのと、実行ファイルから検索するので(静的リンクなので呼ばれる関数は全て含まれるはず)今回はたぶん大丈夫だと思います。
ご指摘ありがとうございました。
No.6
- 回答日時:
sun os は使ったことが無いのですが
GNU の gcc, binutils なら以下でいいと思います。
もし違ったら、同様のコマンドがあるかもしれないので探してみて下さい。
使うのは、
nm => 実行ファイル、オブジェクトファイルからシンボル一覧を出す
c++filt => シンボルをデマングルする
です。
関数 int hoge(int a)と double hoge(double a)が 探したいとして以下のように作業します。
% cat a.cc
int hoge(int a) {
return a*2;
}
double hoge(double a) {
return a*2;
}
int xyz();
int main() {
xyz();
}
% cat b.cc
int hoge(int a);
double hoge(double a);
int xyz() {
return hoge(1) * hoge(2.2);
}
% g++ -c a.cc
% nm a.o | grep hoge
0000000a T _Z4hoged
00000000 T _Z4hogei
% nm a.o | grep hoge | c++filt
0000000a T hoge(double)
00000000 T hoge(int)
% g++ -c b.cc
% nm b.o | grep hoge
U _Z4hoged
U _Z4hogei
% nm b.o | grep hoge | c++filt
U hoge(double)
U hoge(int)
% g++ -o bin a.o b.o
% nm bin | grep hoge
0804840e T _Z4hoged
08048404 T _Z4hogei
% nm bin | grep hoge | c++filt
0804840e T hoge(double)
08048404 T hoge(int)
ありがとうございます。
今日会社でちょうどnmコマンドが使えるかもとアドバイスをもらったところだったので、nmとgrepでなんとか目的が達成できそうでした。
nm -C でデマングルできるようなのですが、マングル化の文字列も同時に出力されてじゃまだったので、週明けに c++filt を試して見ます。
No.5
- 回答日時:
> ソースコードを追って依存関係を調べるのは現実的ではないため
C++の場合、ヘッダファイルにインターフェースを定義しますよね。
makedepend するのが良いでしょう。
ありがとうございます。
makedepend の役割が今回の目的に合致すると思ったのですが、調べてみても、どのように使えばよいのかイマイチわからなかったので、
次の回答者さまから教わった nm を使ってみたいと思います。
No.4
- 回答日時:
★追記。
・http://www.vector.co.jp/soft/winnt/util/se420663 …→『hashs』
これに C のソースが同封されているみたいです。
上手くすれば作り変えられると思います。
・以上。参考に。
参考URL:http://www.vector.co.jp/soft/winnt/util/se420663 …
この回答への補足
気づいたのですが、
CRCなどを計算しなくても、
単純に旧ファイルと新ファイルがバイナリ完全一致するかどうか
比較する方法がありました。
これなら20行程度のプログラムなのでバグの心配もなさそうです。
但し、コンパイラが毎回同じバイナリを出力する仕様だったらなのですが。(作成時刻などがファイル内に含まれていたらアウト)
まずは試してみます。
No.3
- 回答日時:
★CRC32 とかは?
・修正した EXE がどれかだけを見つけたいのなら 50 個ある EXE ファイルの
CRC32 の値を計算しておきます。そして関数を修正したあとまた CRC32 を
計算します。CRC32 が異なる EXE ファイルが影響を受けたものと特定が
できませんかね。
・ただファイルの CRC32 を計算するコマンドが Windows 系のツールばかりで
Sun OS 用のツールが見つかりにくいので自作するとかの方法になります。
ネット検索すればソースが見つかります。
ちょっとしたCRC32比較ツールを作れば出来そうですが…。
どうでしょうか? C/C++ カテゴリだし。
・以上。
参考:
http://search.vector.co.jp/search?query=CRC&path=→『CRC』
http://oshiete1.goo.ne.jp/qa2740939.html→『VC6でCRC64・CRC128が出来るソースを探しています。』
この回答への補足
ファイルのバイナリが変わったかどうかを検知する方法もあったんですね。まずファイルサイズを比較して変わっていたらその時点で影響を受けたとみなせるのでサイズが同じなら今度はハッシュ値を比較する方法を試してみます。
#ハッシュ値を計算する方法は別途調べてみますが、外部からの持込は出来ないので、自作になりそうです・・・
#だったら文字列の検索を自作という手も・・・
ご回答、ありがとうございました。
No.1
- 回答日時:
strings コマンドでバイナリファイルに含まれている文字列を表示できます。
あとはgrepなどにパイプでつなげば検索は可能かと思います。
参考URL:http://www.linux.or.jp/JM/html/GNU_binutils/man1 …
この回答への補足
試してみましたが、stringsではソースコード中のいわゆる文字列
("Hello"など)は出力されるのですが、
int myfunction() などの関数名は出力されませんでした。
バイナリエディタで見ると .__1clmyfunction6F_v_. という感じで
関数名がメタ情報としてアスキー文字列になっているのですが、stringsでは文字列とみなされないようです。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- フリーソフト テキストファイル内を検索したい 1 2022/06/01 08:33
- Visual Basic(VBA) vbaサブフォルダーをワイルドカードで取得したい 2 2022/11/15 08:04
- Excel(エクセル) Excelでの検索結果を含む行だけを表示させたい 5 2023/03/10 17:08
- Visual Basic(VBA) Excel VBAで教えてください 4 2022/05/11 22:20
- Excel(エクセル) capeofdragonと申します Excel2016を使っておりまして 半角又は全角の任意文字列が 2 2022/10/31 13:51
- Excel(エクセル) Excelで漢字人名が勝手に並び変わる(続) 4 2023/03/21 21:28
- その他(プログラミング・Web制作) フォルダ内の特定 拡張子のファイルを一括実行するBat ファイルについて 4 2022/04/17 09:51
- Visual Basic(VBA) サブフォルダ(データ)にある複数の.xlsxファイルのSheet3のA2セルの値で01から左側をB2 2 2022/08/14 15:46
- ドライブ・ストレージ Windows10でのファイル内の文字列検索 SSDに寿命? 4 2022/07/12 03:25
- C言語・C++・C# 至急お願いします。C言語で.imgのファイルを読み込んで1バイトづつ出力するプログラムを作りたいので 3 2023/01/16 22:49
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Boolean型配列中のTrueの有無を...
-
【正規表現】【javascript】CR...
-
サブウインドウから親ウインド...
-
ASP+アクセスでのSQLコメントに...
-
VB6における事前バインディング...
-
Linux バイナリ実行できない "...
-
ボタンをクリックすると数が増...
-
関数を呼び出すHTMLタグ<body o...
-
VB.NETで変数の型は自作...
-
【Jquery】changeイベント毎にa...
-
awk内でsystem関数を使用しfunc...
-
同じ型【ハイフンと数字】だけ...
-
Vb.netのグローバル変数の宣言...
-
引数付きコンストラクタでコン...
-
複数ファイルで使うグローバル...
-
-(ハイフン)_(アンダーバー)の...
-
エクセルでブラウザへのフォー...
-
同じIDで定義した要素の配列を...
-
window.openでタイトル名の指定
-
google apps scriptの終了のさせ方
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Boolean型配列中のTrueの有無を...
-
【正規表現】【javascript】CR...
-
ASP+アクセスでのSQLコメントに...
-
Linux バイナリ実行できない "...
-
Vb.netのグローバル変数の宣言...
-
ボタンをクリックすると数が増...
-
【Jquery】changeイベント毎にa...
-
正規表現で半角数字1桁のみを全...
-
HTTPSのとき":"が"%3A"ではなく...
-
「オブジェクトが必要です。」...
-
onclick指定関数の引数へローカ...
-
同じ型【ハイフンと数字】だけ...
-
Excel VBA の ChangeFileAccess
-
C# .NET DataGridView の行を追...
-
javascriptで文字挿入でtoggle...
-
ifreamをリロードしたい
-
window.onloadでのfunction
-
static constメンバ変数(配列)...
-
MFCのキャプション変更
-
VB6における事前バインディング...
おすすめ情報