link もっと前
   2012年 2月 27日 -
      2012年 2月 27日  
link もっと後

link 未来から過去へ表示(*)
link 過去から未来へ表示

日々

link permalink

Eclipse が固まる

Eclipse のエディタは、変数名をカーソルでポイントすると、変数の型や Javadoc が自動的に出現します。とても便利なのですが、誰も定義していない変数(変数名を typo してるとか)をポイントしてしまうと、何かを探しに行ったまま Eclipse がフリーズします。

特にネットワークドライブなど I/O の遅い場所にプロジェクトを置いていると、現象が顕著に発生します。長いときは十秒くらい反応が返りません。カーソルを動かすたびに誤爆して固まるので、相当イライラします。

今まで我慢して使っていたのですが、いい加減ムカついてきたので原因を探ってみました。

原因

Editor の設定を調べると、どうも固まる原因は Hovers にあるようです。設定はメニューから辿って Window - Preferences - Java - Editor - Hovers にあります。

初期状態だと、
Combined Hover(右側空欄)
Externalized String(Ctrl+Alt)
Source(Shift)
が選ばれていると思います。下記のような意味です。

  • Combined Hover を表示するには何も押さずにポイント
  • Externalized String を表示するには Ctrl+Alt キーを押した状態でポイント
  • Source を表示するには Shift キーを押しながらポイント

Eclipse が固まるときは特にキーを押していませんから、Eclipse が固まる原因は Combined Hover ですが、これは名前の通り複数の機能の複合なのでもう少し絞込みが必要です。

真の原因

Combined Hover の説明を見るにリストの上から順に試してうまく行ったやつを表示するだけらしいので、Combined Hover のチェックをはずして、リストの上から他の機能を一個ずつ試してみます。

上から試した結果、Eclipse を固まらせる真の原因は Hovers の Problem Description だったとわかりました。さらに言うと Problem Description の「変数が未定義エラー」の表示だけが非常に低速です。「クラスが未定義エラー」や「スペルチェッカの警告」の表示はかなり高速です。うーん、何が悪いんでしょうね?

対策

Combined Hover を OFF にするとエディタが使いづらくなるので、良く使う機能(たぶん Javadoc でしょう)を単発で ON にして、Problem Description は暴発しないようにキーを押したときのみ発動させるように、設定を変更すると良いと思います。

個人的には Source は要らないので、
Problem Description(Shift)
Externalized String(Ctrl+Alt)
Javadoc(右側空欄)
としています。

注意点

Shift, Ctrl, Alt で 2^3 = 8通り(何も押さない場合を含んで)の組み合わせができますが、意外と Hover と組み合わせられるキーは少ないです。

ShiftCtrlAlt 説明
× × × 何も押さずにポイントしたときがこれ。
× × 使えるが、キーを離すとメニューにフォーカスが移ってしまって使いづらい。
× × 使えません、Eclipse のエディタの機能と衝突していて Hover が発動しません。
× 使える、デフォルトでは Externalized String に割り当て。
× × 使える、デフォルトでは Source に割り当て。
× 使えるが、キーを離すとメニューにフォーカスが移ってしまって使いづらい。
× 使える。
使えるが、3つも押すのが面倒くさい。

以上から、使いやすいのは、(何も押さない), Shift, Shift + Ctrl, Ctrl + Alt の 4つくらいですかねえ。

[編集者: すずき]
[更新: 2012年 2月 29日 20:31]
link 編集する

コメント一覧

  • コメントはありません。
open/close この記事にコメントする



link もっと前
   2012年 2月 27日 -
      2012年 2月 27日  
link もっと後

管理用メニュー

link 記事を新規作成

合計:  counter total
本日:  counter today

link About www.katsuster.net
RDF ファイル RSS 1.0
QR コード QR コード

最終更新: 2/21 00:46

カレンダー

<2012>
<<<02>>>
---1234
567891011
12131415161718
19202122232425
26272829---

最近のコメント 5件

  • link 18年12月11日
    すずき 「確認いただいてありがとうございます。直っ...」
    (更新:12/27 00:22)
  • link 18年12月11日
    T4 「再現しませんね\n\n確かに、過去にそう...」
    (更新:12/25 12:45)
  • link 18年12月11日
    すずき 「失礼しました。Rock64 の方は、\n...」
    (更新:12/22 02:10)
  • link 18年12月11日
    T4 「私は、Tinker Board を持って...」
    (更新:12/21 10:14)
  • link 18年12月11日
    すずき 「> 但し、これもう一年以上前の話で...」
    (更新:12/19 11:54)

最近の記事 3件

link もっとみる
  • link 19年02月19日
    すずき 「[RISC-V のコンパイラ] Crosstool-NG は RI...」
    (更新:02/21 00:46)
  • link 19年02月18日
    すずき 「[RockPro64 のシリアル出力] RockPro64 のシリ...」
    (更新:02/21 00:43)
  • link 19年02月20日
    すずき 「[RockPro64 の HDMI Audio] RK3399 の...」
    (更新:02/21 00:33)

こんてんつ

open/close wiki
open/close Java API

過去の日記

open/close 2002年
open/close 2003年
open/close 2004年
open/close 2005年
open/close 2006年
open/close 2007年
open/close 2008年
open/close 2009年
open/close 2010年
open/close 2011年
open/close 2012年
open/close 2013年
open/close 2014年
open/close 2015年
open/close 2016年
open/close 2017年
open/close 2018年
open/close 2019年
open/close 過去日記について

その他の情報

open/close アクセス統計
open/close サーバ一覧
open/close サイトの情報