質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.53%

  • Java

    15526questions

    Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

  • Eclipse

    1878questions

    Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

eclipse上でのjavaのデバッグ実行の仕組みについて

解決済

回答 1

投稿

  • 評価
  • クリップ 1
  • VIEW 5,835

nob777

score 103

eclipse上でのjavaのデバッグ実行時の仕組みについてご教授願います。

eclipse上でjavaをデバッグ実行中に該当ソースのclassファイル情報を確認しましたが、
特に更新されておらず、リコンパイルされているようには見受けられませんでした。
eclipse上でのデバッグ時の内部動作として"-g"オプション付きでリコンパイルされると思い込んでいましたが違うようです。

■質問
 eclipse上でのjavaのデバッグ実行時の仕組みについてご教授願います。
 なぜ、デバッグ実行時にclassファイルが更新されていないのでしょうか?
 デバッグ情報が埋め込まれたclassファイルは生成されるが、メモリ上のみに展開されているというような動作となっているのでしょうか?それとも別フォルダに一時的にclassファイルを生成している?

以上、よろしくお願いいたします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+3

Eclipse はデフォルトの設定ではデバッグ情報ありでコンパイルしていると思いますよ。

Window->Preferences->Java->Compiler の Classfile Generation 

を見てみてください。
(Eclipse のバージョン等によって場所は多少違うかもしれません)

Compilerオプションの初期状態

(参考)デバッグ情報を切るとどうなるか

例えばプロジェクトローカルの設定で(プロジェクト右クリック->Preference)
以下のようにデバッグ情報出力のチェックボックスを外したとします。

Compilerオプションからデバッグ情報出力を外した状態

この状態でブレークポイントを設定してデバッグ実行しようとすると、以下のようなエラーダイアログが表示されます。
デバッグ情報が無い場合のエラーダイアログ

「実行(Run As)」と「デバッグ(Debug As)」の使い分けについて

開発チームの意図を直接ドキュメントで読んだわけではないですが、
使っている感覚としては、「「実行」と同じことを(条件を変えずに)デバッガ上で実行する」というイメージで使っています。

これは、Eclipse のような IDEを使う以前に、
コマンドラインで開発していたときのやり方の延長です。

コマンドライン開発では、

  • 単に実行するとき: コンパイラが出力した実行ファイルを直接実行
  • デバッグするとき:同じ実行ファイルをデバッガから起動、

というやり方をしていました。

デバッグをするときは、デバッガというデバッグのためのプログラムを動かして、
その上で同じ実行ファイルを動かしていたのです。
現在の「デバッグ」で実行してデバッグパースペクティブに切り替えるのは、
この「デバッガを起動してデバッグをする」というような感覚です。
やることを切り替えるというより、同じことをブレークポイントなどが効く環境にから実行しなおすという感じです。

デバッグ用情報の出力に関して

デバッグをするからデバッグ用にコンパイルしなおすというようなことはあまりしていませんでした。
開発中はデバッグ情報を ONのままにして、テストが十分終わった後、
パフォーマンスのためにデバッグ情報を OFF にしたり最適化オプションを ON にしたりしていました。
実際には、パフォーマンスを極限まで必要とされる用途(CAD等の科学技術演算)を除いては、
デバッグ情報を残したまま運用まで行うことも多かったです。
これは、障害が起きた場合の原因解明のしやすさの方が、多少のパフォーマンス低下よりも重要だと
考えられるような場合です。
障害が起きたら、障害を起こした時点と同じ実行ファイルをデバッガにかけて障害の原因を調べたのです。

現在の Java のアプリケーションでは、デバッグ情報を外すことはめったにないと考えていいと思います。
極限のパフォーマンスを追及するような用途では C/C++ が使われますし、
絶対的なパフォーマンスよりも運用の安定性、障害復旧の迅速さといったことの方が
重要度が高い場合が多いからです。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/02/21 00:15

    ご回答いただきありがとうございました。
    実行方法に、「実行」と「デバッグ」を選択できるようになっています。
    また、「デバッグ」を選択した場合のみブレークポイントで止まるため、誤った理解をしておりました。
    (デバッグ・パースペクティブの起動有無等、別の理由で分けているのでしょうか・・・)

    キャンセル

  • 2016/02/21 00:51

    そのあたりの説明が無かったので、「「実行(Run As)」と「デバッグ(Debug As)」の使い分けについて」の説明、というか、「こういう感じで使っている」という話を回答に追加してみました。
    ご興味があれば参考までに見てみてください。

    キャンセル

  • 2016/02/21 01:38

    とても分かりやすい説明をしていただき感謝しております。
    以前、実運上でサーバーサイドのjavaをjavapで確認する機会がありましたが、
    その環境でも確かにデバッグ情報が埋め込まれていました。

    キャンセル

同じタグがついた質問を見る

  • Java

    15526questions

    Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

  • Eclipse

    1878questions

    Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。