コア FindBugs プラグイン
このプラグインにはすべての標準的な FindBugs ディテクタがあります。

]]>
http://findbugs.sourceforge.net/bugDescriptions_ja.html http://findbugs.sourceforge.net/bugDescriptions_ja.html
add msgs (e.g., textual descriptions of bugs) to analysis results Perform FindBugs Analysis Launch FindBugs GUI Convert analysis results to textual form Provide help for commands List FindBugs version Filter analysis results Set project configuration/options List details from multi-version analysis results Merge analysis results from disjoint components Combine analysis results from different versions of software to produce multi-version analysis results Disassemble a class file List analysis errors stored in results file (クラウド無効)
このプラグインを使うとバグレビューは無効になります。
マルチスレッドの正確性問題を抑止する
すべてのマルチスレッドの正確性問題を抑止します
国際化問題を抑止する
すべての国際化問題を抑止します
選択したパッケージ以外のすべての国際化問題を抑止する
i18n.properties リソースで指定した以外のすべての国際化問題を抑止します
ランク14を越えるすべての問題を抑止する
ランク14を越えるすべての問題を抑止します
悪意のあるコード脆弱性について警告を抑止する
悪意のあるコード脆弱性について警告を抑止します
正確性 C
バグの可能性 - おそらく、開発者が意図していなかったコードになっている明らかなコーディング間違いです。 我々は低い誤検出率のために努力します。
偽のランダムノイズ N
偽のランダムノイズ: ソフトウェアで実際のバグを発見するのではなく、データマイニング実験のコントロールとして役に立つことを意図しました。
セキュリティ S
リモートから利用可能なセキュリティ脆弱性を作成できる信頼できない入力を使用しています。
バッドプラクティス B
推奨または必須のコーディングプラクティスの違反です。たとえば、hashCode と equals の問題、cloneable イディオム、捨てられた例外、Serializable の問題、finalize の誤用などです。 いくつかのグループはバッドプラクティスを気にしないかもしれないが、我々は正確な解析をしようと努力します。
危ないコード D
紛らわしいコード、変則的なコード、それ自身をエラーに導く方法で書かれたコードです。 たとえば、ローカル変数への無効な代入、switch 文のフォールスルー、未確認のキャスト、null とわかっている値の冗長な null チェックなどです。 より多くの誤検出を受け入れました。 FindBugs の以前のバージョンでは、このカテゴリは Style として知られていました。
性能 P
必ずしも間違っているというわけではなくて、効率が悪いかもしれないコード
悪意のあるコード脆弱性 V
信頼できないコードからの攻撃に脆弱であるコード
マルチスレッドの正確性 M
スレッド、ロック、volatile に関係があるコードの欠陥
国際化 I
国際化とロケールに関係があるコードの欠陥
実験用 X
実験用で完全に精査されていないバグパターン
このディテクタは、ほぼ (しかし、正確ではなく) 同じである Math.PI のような既知の定数を見つけます。

]]>
Finds nonnull fields that are not written to in constructors. このディテクタは、コンストラクタで書き込まれない非 null フィールドを見つけます。

]]>
このディテクタは、エポックからミリ秒を記述する32ビット値の使い方を見つけます。

]]>
このディテクタは、エポックからミリ秒を記述している64ビット値を取るパラメータのデータベースを構築します。

]]>
このディテクタは、型修飾子が直接適用されるメソッドパラメータとそれらのメソッドパラメータの使い方との間で矛盾を見つけます。

]]>
このディテクタは、原子的に実行されない並行抽象化に関して、演算(たとえば、get/put)のシーケンスを見つけます。

]]>
このディテクタは、共有された組込み定数 (たとえば、String) の同期化を探します。

]]>
このディテクタは、同期化されたフィールドを null チェックしているコード探します。

]]>
このディテクタは、net.jcip.annotations.Immutable または javax.annotation.concurrent.Immutable としてアノテートされたクラスのルール違反を探します。

]]>
このディテクタは、J2SE 5.0の可変長引数に起因する問題を探します。

]]>
このディテクタは、net.jcip.annotations パッケージからアノテーションを記録します。

]]>
このディテクタは、メソッドを解析することに関連する型修飾子に注意します。

]]>
このディテクタは、プロシージャー間の呼び出しグラフを構築します。

]]>
このディテクタは、FindUnsatisfiedObligation ディテクタによって使われる責務の種類とメソッドのデータベースを構築します。

]]>
このディテクタは、edu.umd.cs.findbugs.annotations.NoteSuppressWarnings アノテーションの使い方に基づく警告を抑止します。

]]>
このディテクタは、Retention アノテーションを記録します。

]]>
このディテクタは、合成クラス、メソッド、フィールドなどを記録します。

]]>
このディテクタは、他のディテクタが使用するための解析されたクラスで定義されているすべてのメソッドのデータベースを構築します。

]]>
このディテクタは、どのクラスが .class オブジェクトへの定数参照を持っているのか決定しようと試みます。

]]>
このディテクタは、他のディテクタが使用するための解析されたクラスで呼び出されるすべてのメソッドのデータベースを構築します。

]]>
値を返すだけの副作用を持たないメソッドを探します。

]]>
このディテクタは、メソッドから変化していないメソッドに渡された文字列パラメータのデータベースを構築します。

]]>
このディテクタは、クラスの新しいインスタンスを返すメソッドがある不変クラスを探します。 メソッドが呼び出されるとインスタンスが変化させられると思います。

]]>
このディテクタは、継承されたメソッドと外部のメソッドとの潜在的混同を探します。

]]>
このディテクタは、メソッドの戻り値をチェックするためにアノテーションを探します。

]]>
このディテクタは、クラスリテラルではなく、getClass の結果で同期化するコードを探します。

]]>
このディテクタは、何がフィールドに格納されたのかについて、サマリー情報を作り出します。

]]>
このディテクタは、メソッド、フィールド、パラメータで @Nonnull アノテーションを探します。 null かもしれない値が null でない値だけが使われるべき文脈で使われたとき警告を生成するために FindNullDeref ディテクタはこれらを使用できます。

]]>
このディテクタは、無条件にパラメータの参照外しが行われるのかを決定するためにアプリケーションのすべてのメソッドを解析します。 この情報は、null 値がメソッドに渡されるかもしれない呼び出し場所を発見するために後の解析パスで使われます。

低速ディテクタです。

]]>
このディテクタは、どのメソッドが常に非 null 値を返すのかを決定するためにアプリケーションのすべてのメソッドを解析します。

]]>
このディテクタは、明示的に null 値を返す戻り型が Boolean のメソッドを探します。

]]>
このディテクタは、Optional の戻り型が明示的に null 値を返すメソッドを探します。

]]>
このディテクタは役に立たないオブジェクトを探します。

]]>
このディテクタは、可変列挙型フィールドを探して警告します。

]]>
このディテクタは、メソッドの戻り値を null でないのかチェックした後で捨てるケースを探します。

]]>
このディテクタは、クラスが別のパッケージのクラスによって拡張されるなら、予想外の結果をもたらす可能性がある this.getClass().getResource(...) の使用を探します。

]]>
このディテクタは、無限再帰ループを探します。

]]>
このディテクタは、無限ループを探します。

]]>
このディテクタは、volatile フィールドの使い方のバグパターンを探します。

]]>
このディテクタは、空の zip ファイルエントリの作成を探します。

中速ディテクタです。

]]>
このディテクタは、無名内部クラスに定義されたメソッドで、スーパークラスのメソッドをオーバーライドすることを意図していますが、実際はオーバーライドになっていないメソッドを探します。

]]>
このディテクタは、フィールドとメソッドが J2SE 5.0のキーワードである assert や enum を名前として使用していないことをチェックします。

]]>
java.net.URL の equals と hashCode メソッドはドメイン名の解決をします。 その結果、これらの演算はかなり高くつきます。このディテクタは、メソッドが呼び出されるかもしれない場所を探します。

]]>
このディテクタは、クラスのフィールドを null にするファイナライザを探します。 どんな方法でもフィールドを null にすることは効果がなく、ガベージコレクタの助けになりません。

]]>
このディテクタは XSS 脆弱性の自明で露骨なケースを探します。

]]>
このディテクタは、(x == 5 || x == 5) のような繰り返される条件テストを含んでいるコードを探します。

]]>
このディテクタは、この式の2番目の条件のような役に立たない条件を含んでいるコードを探します (x >= 10 && x >= 5).

]]>
このディテクタは、サポートされていないメソッドの呼び出しを探します。

]]>
このディテクタは、間違った書式文字列をチェックします。

]]>
このディテクタは、equals メソッドを定義しているクラスと互換性がないクラスのインスタンスをオペランドにしてチェックする equals メソッドをチェックします。

]]>
このディテクタは、新しいディテクタをテストするためのフックです。通常このディテクタは何もしません。

]]>
このディテクタは、新しいディテクタをテストするためのフックです。通常このディテクタは何もしません。

]]>
このディテクタは、 OpenJDK 1.6の下で異なる振る舞いをするコードを探します。OpenJDK 1.6では、Logger を保持するのに弱参照が使われます。

]]>
このディテクタは、新しいディテクタをテストするためのフックです。通常このディテクタは何もしません。

]]>
このディテクタは、ランダムな信号を生成します。メソッドによって実行される演算のハッシュ値に基づく警告です。 これらの警告はソフトウェアで実際のバグを発見するのではなく、データマイニング実験のコントロールとして役に立つことを目的とした偽のランダムノイズです。

このディテクタは、新しいディテクタをテストするためのフックです。通常このディテクタは何もしません。

]]>
null の参照解除のためのノイズが多いディテクタです。コードの問題を見つける方法として使用するのではく、警告の妥当性または予測能力の実験でコントロールとして役に立つことを意図しました。

]]>
このディテクタは、複数のクラスファイルにわたって複製されている文字列定数を探します。

]]>
このディテクタは、doPrivileged ブロックの中で実行するべきコードを探します。

]]>
このディテクタは、すべての参照呼び出しが解決されることをチェックします。

]]>
このディテクタは、フォールスルーがある switch 文を探します。

]]>
このディテクタは、フィールドが同じフィールドの値を読み出して代入される場所を探します。

]]>
このディテクタは、値がそれ自身と比較される場所を探します。

]]>
このディテクタは、値がそれ自身と比較される場所を探します。

]]>
このディテクタは、非短絡論理演算子の疑わしい使用を探します(||&& の代わりに |&)。

]]>
このディテクタは、IllegalMonitorStateException をキャッチする try-catch ブロックを探します。

]]>
このディテクタは、浮動小数点演算の使用を探します。

中速ディテクタです。

]]>
このディテクタは、Cloneable クラスを書くためのイディオムの違反を探します。

]]>
このディテクタは、Comparator を実装するクラスを書くためのイディオムの違反を探します。

]]>
このディテクタは、例外をキャッチしていますが、何もしていないコードを探します。

]]>
このディテクタは、null とわかっている値の読み出しを探します。

]]>
このディテクタは、メソッド (例:substring(0)) に渡されている間違った引数を探します。

]]>
このディテクタは、引数のない String コンストラクタのような無意味なメソッドの呼び出しを探します。

]]>
このディテクタは、実行時に ArrayStoreException を引き起こすかもしれない Object[] array = new String[10] のような共変配列代入を探します。

]]>
このディテクタは、Number コンストラクタのプリミティブ型の引数による呼び出しを探します。

]]>
このディテクタは、ダブルチェックロッキングのインスタンスを探します。

]]>
このディテクタは、finalize メソッドの呼び出しと他のファイナライザ関連の問題を探します。

]]>
このディテクタは、hashCode メソッドと equals メソッドの定義の問題を探します。

]]>
このディテクタは、同値関係が対称的でないかもしれないスーパークラスの equals メソッドをオーバーライドする equals メソッドを探します。

]]>
このディテクタは、可変オブジェクトの状態を変更するように思われない notify メソッドの呼び出を探します。

]]>
このディテクタは、可変静的データを返すメソッドを探します。

]]>
このディテクタは、Thread.run() の呼び出しを探します。

高速ディテクタです。

]]>
このディテクタは、条件式またはループ内で呼び出されない wait メソッドを探します。

]]>
このディテクタは、2つ以上のロックを保持している状態で、wait メソッドの呼び出しを探します。

低速ディテクタです。

]]>
このディテクタは、条件文、またはループの中にない wait メソッドの呼び出しを探します。

]]>
このディテクタは、コンストラクタで初期化されていないフィールドの読み出しを探します。

]]>
このディテクタは、set メソッドは同期化していて get メソッドは同期化していない get メソッドと set メソッドを探します。

]]>
このディテクタは、潜在的循環クラス初期化依存関係を探します。

]]>
このディテクタは、イテレータクラスの定義方法の問題を探します。

]]>
このディテクタは、ロックに関して一貫性のない方法でアクセスされるフィールドを探します。

]]>
このディテクタは、== や != 演算子を使用している String オブジェクトの比較を探します。

]]>
このディテクタは、変更されたフィールドから読み込まれるオブジェクトの同期化を探します。

]]>
このディテクタは、フィールドの更新をガードするためにフィールドを同期化しているように思われるコードを探します。

]]>
このディテクタは、悪意のあるコードによって変更されるかもしれない static フィールドを探します。

]]>
このディテクタは、疑わしげに命名されたメソッドを探します。

]]>
このディテクタは、戻り値が無視される InputStream.read() または InputStream.skip() の呼び出しを探します。

]]>
このディテクタは、Serializable クラスの実装の潜在的な問題を探します。

]]>
このディテクタは、スレッドを開始するコンストラクタを探します。

]]>
このディテクタは、間違った for ループを探します。

]]>
このディテクタは、このクラスが本当に直列化されるという証拠として readObject と writeObject を通して明示的な直列化を探します。

]]>
このディテクタは、値が決して読み出されないフィールドを探します。

]]>
このディテクタは、ループの中にない wait メソッドの呼び出しを探します。

]]>
このディテクタは、戻り値が疑わしげに無視されるメソッドの呼び出しを探します。

低速ディテクタです。

]]>
このディテクタは、Comparator.compare または Comparable.compareTo の実装における問題を探します。

]]>
このディテクタは、NullPointerException が発生するかもしれない場所を探します。 また、null に対する参照値の冗長な比較を探します。

低速ディテクタです。

]]>
このディテクタは、NullPointerException が発生するかもしれない場所を探します。 非短絡評価の使用はありふれたテクニックで失敗の原因になります。

]]>
このディテクタは、メソッドから脱出しないで、メソッドからのすべての経路でクローズされるように見えない IO ストリームオブジェクトを探します。

低速ディテクタです。

]]>
このディテクタは、配列か明示的に null 参照を返すメソッドを探します。 長さが0の配列を返すことは、この文脈において null 参照を返すより好ましいです。

]]>
このディテクタは、効果がない制御フロー文を探します。

]]>
このディテクタは、JSR-166(java.util.concurrent) のロックを獲得したのにメソッドからのすべての経路で解除されないロックを探します。

中速ディテクタです。

補助クラスパスに java.util.concurrent パッケージ (またはパッケージ自体を解析している) が必要であることに注意してこのディテクタを使用してください

]]>
このディテクタは、2つの参照値を == や != 演算子で比較している場所を探します。 java.lang.String のような型のクラスの参照値を比較することは一般的に誤りです。

低速ディテクタです。

]]>
このディテクタは、現在ロックされているオブジェクトで作成されるように見えない wait メソッド、notify メソッド、notifyAll メソッドの呼び出しを探します。

中速ディテクタです。

このディテクタは、まだ開発中で、あまりに多くの誤検出が発生するので、無効にされています。

]]>
このディテクタは、空の synchronized ブロックを探します。

]]>
このディテクタは、ロックに関して一貫性のない方法でアクセスされるフィールドを探します。

低速ディテクタです。

]]>
このディテクタは、ローカル変数の自己代入を探します。

]]>
このディテクタは、疑わしいビット論理式を探します。

]]>
このディテクタは、フィールドが volatile でない怠惰なフィールドの初期化を探します。

中速ディテクタです。

]]>
このディテクタは、JSR-166のロックで実行される通常の同期化を探します。

中速ディテクタです。

]]>
このディテクタは、決して呼び出されない private メソッドを探します。

]]>
このディテクタは、+を使ったループによる文字列の連結を探します。

]]>
このディテクタは、パフォーマンスを向上させるために外側に移せるループ内で初期化しているオブジェクトを探します。

]]>
このディテクタは、String.indexOf(String) または String.lastIndexOf(String) を使用して定数に長さ1の文字列を渡すコードを探します。 より効率的な整数実装を使用することを推奨します。 高速ディテクタです。

]]>
このディテクタは、toArray(T[] a) メソッドに長さが0の配列を渡してコレクションを配列に変換するコードを探します。

]]>
このディテクタは、不正な形式の JUnit テストを探します。

]]>
このディテクタは、Adapter クラスを拡張して、間違ったシグネチャで Listener メソッドをオーバーライドするコードを探します。

]]>
このディテクタは、列インデックス番号が0の ResultSet の getXXX または setXXX メソッドの呼び出しを探します。 ResultSet の列インデックス番号は1で始まるので、これは常に間違いです。

]]>
このディテクタは、静的に判定される instanceof 演算子を使用している型チェックを探します。

]]>
このディテクタは、Applet スタブに依存する親 Applet でメソッドを呼び出す Applet コンストラクタを探します。 このスタブは init メソッドの前まで初期化されないので、これらのメソッドはコンストラクタで失敗します。

]]>
このディテクタは、非スタティックな文脈から Thread.interrupted() の呼び出しを探します。 Thread.currentThread().interrupted() から呼び出されるなら、役に立たない行為なので Thread.interrupted() を使用します。 しかしながら、interrupted メソッドは常にカレントスレッドで呼び出されるので、任意のスレッドオブジェクトで呼び出すのはほぼ間違いなく誤りです。

]]>
このディテクタは、switch 文で定数文字列以外の何かが引数として渡される SQL 文の execute メソッドの呼び出しを探すためにデータフロー解析を使います。

]]>
このディテクタは、その後、決して読み出されないローカル変数への代入を探します。

中速ディテクタです。

]]>
このディテクタは、メソッドで定義されたローカル変数によって隠されるフィールドを探します。

]]>
このディテクタは、keySet イテレータから取り出されたキーを使用して Map エントリの値にアクセスするコードを探します。

]]>
このディテクタは、static メソッドしか定義していないクラスのオブジェクトを作成しているコードを探します。

]]>
このディテクタは、ブロックの中のコードが例外をスローしないのに例外をキャッチする catch 節を探します。

]]>
このディテクタは、浮動小数点の等価式を探します。

高速ディテクタです。

]]>
このディテクタは、メソッドからのすべての経路でクリーンアップされない入出力ストリームとデータベースリソースを探します。

低速ディテクタです。

]]>
このディテクタは、計算結果が静的に知られている値を計算するために java.lang.Math の static メソッドを呼び出すコードを探します。 その代わりに定数を使用する方がより高速で、ときにはより正確です。

]]>
このディテクタは、クラス間の循環依存関係を探します。

]]>
このディテクタは、スーパークラスと同じインタフェースを実装すると宣言しているサブクラスを探します。 スーパークラスがインタフェースを実装しているので、サブクラスで同じことをするのは冗長です。

]]>
このディテクタは、Struts フレームワークを実装する際の潜在的な問題を探します。

]]>
このディテクタは、同期化して this に対して wait メソッド、notify メソッド、notifyAll メソッドを使用する public クラスを探します。 これは public クラスの同期化実装を暴露することになります。public クラスの利用者は、利用者のクラスで public クラスのインスタンスを同期化オブジェクトとして使うかもしれません。 これはベース実装に大惨事をもたらします。

]]>
このディテクタは、戻り値が疑わしげに無視されるメソッドの呼び出しを探します。

]]>
このディテクタは、整数除算の結果が double にキャストされる場所を探します。 多くの場合、意味されたことは、整数オペランドを double にキャストしてから除算を実行することでした。

]]>
このディテクタは、データフロー解析を使用してオブジェクト参照の間違ったキャストを探します。

]]>
このディテクタは、HTTP セッションへの非直列化オブジェクトの格納を探します。

]]>
このディテクタは、それらが直列化可能であることを要求するコンテキストで、非 Serializable オブジェクトの使用を探します。

]]>
このディテクタは、ObjectOutputwriteObject メソッドに渡される非 Serializable オブジェクトを探します。

]]>
このディテクタは、無効な構文がある正規表現を探します。

]]>
このディテクタは、Joshua Bloch と Neal Gafter が『Java Puzzlers』で言及した多方面にわたるささいな誤りを探します。

]]>
このディテクタは、ロックを保持している状態での Thread.sleep() の呼び出しを探します。

低速ディテクタです。

]]>
このディテクタは、2つの分岐に同じコードがある if/else または switch 文を探します。 これは多くの場合、2つの分岐に同じコードをコピー & ペーストしていることが片方の分岐の間違ったロジックの原因になります。

]]>
このディテクタは、所有クラスの private フィールドに書き込んでいる内部クラスを探します。 この場合、コンパイラは必ずこのフィールドへ書き込むことに使われるアクセッサーメソッドを生成します。 可視性を protected に緩和することは、フィールドに直接書き込むことを可能にします。

]]>
このディテクタは、XML インタフェースを実装したクラスのインスタンスを直接生成しているコードを探します。 これらのオブジェクトを作成するために提供されたファクトリパターンを使用するのではなく、特定の実装にコードを結びつけます。

]]>
このディテクタは、スーパークラスで定義されたメソッドを実装して、スーパークラスのメソッドにパラメータをそのまま渡しているだけのサブクラスを探します。 これらのメソッドは除去できます。

]]>
このディテクタは、protected メンバを宣言する final クラスを探します。 このクラスは派生させることができないので、protected メンバの使用は正しくありません。 アクセス権は、メンバの正しい意図を表すために public か private に変更するべきです。

おそらく、新しいパラダイムにクラスのすべてを完全に変更することではなく、クラスの使用中の変化が原因となりました。

]]>
このディテクタは、条件式で変数にリテラルブール値の単純な代入を探します。 ]]>
このディテクタは、どのメソッドが null を返すのかを決定してファイルに保存します。 結果ファイルは、null 間接参照ディテクタの精度を向上させるために後続のパスで使われることがあります。 これはトレーニングパスなので警告は報告されません。

低速ディテクタです。

]]>
このディテクタは、どのメソッドが無条件に null の参照外しを行うのかを決定してファイルに保存します。 結果ファイルは、 null 間接参照ディテクタの精度を向上させるために後続のパスで使われることがあります。 これはトレーニングパスなので警告は報告されません。

低速ディテクタです。

]]>
このディテクタは、フィールドに格納される型を解析してデータベースに保存します。 データベースは、型解析をより正確にするために後続のパスで使われることがあります。

低速ディテクタです。

]]>
このディテクタは、@Nonnull と @PossiblyNull アノテーションを集めて、データベースに保存します。

高速ディテクタです。

]]>
このディテクタは、FindBugs でメソッド呼び出しの解決をデバッグするためにあります。

有効にしないでください。

]]>
このディテクタは、解析過程のサマリー統計情報を収集します。 ]]>
このディテクタは、ASM バイトコード解析フレームワークを使用した FindBugs ディテクタを書く方法を示しているコード例です。

]]>
このディテクタは、引数の型がコレクションのパラメータに関連しているかどうか確かめるために java.lang.Object を受け取る総称型コレクションメソッドへの呼び出しの引数を見ます。 無関係なクラス型による引数は決してコレクションの中に格納されることはありません。 たとえば、fooList<String> で、barStringBuffer なら foo.contains(bar) の呼び出しは常に false を返すことになります。

高速ディテクタです。

]]>
Calendar は、マルチスレッドでの使用は本質的に安全ではないので、このディテクタは、java.util.Calendarjava.text.DateFormat (サブクラスも) の static フィールドについて警告します。

]]>
これはデータフロー解析を検証するためにだけ使われる内部のディテクタです。

デフォルトでは有効にされません。

]]>
このディテクタは、JSR-305 の型修飾子アノテーションで特定されたプロパティの違反をチェックします。

]]>
このディテクタは、オブジェクト出力ストリームに追加しようとする試みを探します。

]]>
このディテクタは、@ExpectedWarning と @NoWarning アノテーションをチェックします。 このディテクタは、FindBugs をテストするためだけに使われます。

]]>
このディテクタは、ConcurrentMapputIfAbsent メソッドの結果が無視されるなら、2番目の引数として渡された値が再利用されていないことをチェックします。

]]>
このディテクタは、スーパークラスのためのコンストラクタから呼び出されるメソッドをチェックします。

]]>
このディテクタは、ユーザのデフォルトプラットホームエンコーディングを使用して、バイトから String (またはString からバイト) に変換するメソッドの呼び出しをチェックします。 これはアプリケーションの振る舞いがプラットホーム間で異なる原因となります。

]]>
このディテクタは、オーバライドメソッドが 戻り値またはパラメータの @CheckForNull (@Nonnull で作られた) で @Nonnull (@CheckForNull で作られた) を緩和していないことをチェックします。

]]>
既知の定数の大雑把な値を見つけた {3} の大雑把な値を見つけました: {2}
コードの明確さともっと良い正確さのために定義済みライブラリ定数を使用することを推奨します。

]]>
解析するにはあまりにも大きいクラス {0} は、解析するにはあまりにも大きいです。
このクラスは効率的に処理できないほど大きいです。また、エラーのために完全に解析されませんでした。

]]>
null ポインタ間接参照に関する偽の警告 null ポインタ間接参照に関する偽の警告です。{1}
偽の警告です。

]]>
メソッド呼び出しに関する偽の警告 メソッド呼び出し {2} に関する偽の警告です。{1}
偽の警告です。

]]>
フィールド参照に関する偽の警告 フィールド参照 {2} に関する偽の警告です。{1}
偽の警告です。

]]>
演算に関する偽の警告 演算 {2} に関する偽の警告です。{1}
偽の警告です。

]]>
正確に表されない double から構築された BigDecimal {4} から BigDecimal が構築されています。{1}
このコードは10進数の数にうまく変換されない double 値から BigDecimal を作成しています。 たとえば、Java で new BigDecimal(0.1) と書くと、0.1と正確に等しい BigDecimal (スケールが1でスケールなしの値が1) が作成されると思うかもしれませんが、 実際には0.1000000000000000055511151231257827021181583404541015625と等しくなります。

おそらく BigDecimal.valueOf(double d) メソッドの使用が望ましいです。BigDecimal(たとえば、BigDecimal.valueOf(0.1) は0.1を与えます) を作成するためには double の文字列表現を使用します。

]]>
D'oh! 無意味なメソッド呼び出し D'oh! {2.nameAndSignature} の無意味なメソッド呼び出し。{1}
この部分的なメソッド呼び出しは、検査から明らかな理由で意味がありません。

]]>
EasyMock メソッドへの役に立たない/無意味な呼び出し EasyMock メソッド {2} の呼び出しは役に立たない/無意味です。{1}
この呼び出しは EasyMock メソッドにどんなオブジェクトも渡さないので何もしません。

]]>
コアプールサイズが0の ScheduledThreadPoolExecutor の作成 コアプールサイズが0の ScheduledThreadPoolExecutor を作成しています。{1}
コアプールサイズが0の ScheduledThreadPoolExecutor は決して何も実行しません。 最大プールサイズへの変更は無視されます。
(Javadoc)

]]>
ScheduledThreadPoolExecutor の最大プールサイズを変えようとする無駄な試み ScheduledThreadPoolExecutor の最大プールサイズを変えようとするのは無駄な試みです。{1}
ScheduledThreadPoolExecutorThreadPoolExecutor から継承されますが継承されたチューニングメソッドの一部は有用ではありません。 特に、corePoolSize スレッドとアンバウンド形式のキューを使用する固定サイズプールとして動作するので、maximumPoolSize の調整は有用な効果がありません。
(Javadoc)

]]>
サポートされていないメソッドの呼び出し サポートされていないメソッド {2} を呼び出しています。{1}
このメソッド呼び出しのすべてのターゲットは UnsupportedOperationException をスローします。

]]>
空のデータベースパスワード 空のデータベースパスーワードです。{1}
このコードは空白または空のパスワードを使用してデータベース接続を作成しています。 これはデータベースがパスワードによって保護されていないことを示しています。

]]>
ハードコードされた定数データベースパスワード ハードコードされた定数データベースパスワードです。{1}
このコードはハードコードされた定数パスワードを使用してデータベース接続を作成しています。 ソースコードかコンパイルされたコードへアクセスできる人なら誰でも簡単にパスワードを知ることができてしまいます。

]]>
信頼できない入力から形成された HTTP cookie HTTP cookie は信頼できない入力から形成されました。{1}
このコードは信頼できない HTTP パラメータを使用して HTTP クッキーを構築しています。 このクッキーが HTTP レスポンスに追加されるなら、HRS(HTTP レスポンススプリッティング) 脆弱性を可能にします。
詳細は、http://en.wikipedia.org/wiki/HTTP_response_splitting を参照してください。

FindBugs は、HRS の最も露骨で自明なケースだけを探します。 FindBugs が何かを派遣したならほぼ間違いなく FindBugs が報告しないより多くの脆弱性があるでしょう。 HRS を心配するなら、商用の静的解析ツールかペネトレーションテストツールの使用を真剣に検討するべきです。

]]>
HTTP レスポンススプリッティング脆弱性 HTTP ヘッダ出力に HTTP パラメータを直接書き込んでいます。{1}
このコードはHTTP ヘッダに HTTP パラメータを直接書き込んでいます。これは HRS(HTTP レスポンススプリッティング) 脆弱性を可能にします。
詳細は、http://en.wikipedia.org/wiki/HTTP_response_splitting を参照してください。

FindBugs は、HRS の最も露骨で自明なケースだけを探します。 FindBugs が何かを見つけたならほぼ間違いなく FindBugs が報告しないより多くの脆弱性があるでしょう。 HRS を心配するなら、商用の静的解析ツールかペネトレーションテストツールの使用を真剣に検討するべきです。

]]>
サーブレットの相対パストラバーサル 相対パストラバーサル。{1}
ソフトウェアは、制限されたディレクトリ内にあるべきパス名を構築するためにHTTPリクエストのパラメータを使いますが、パラメータはそのディレクトリの外にある場所に解決できる「..」のようなシーケンスを適切に無効にしていません。 詳細は、http://cwe.mitre.org/data/definitions/23.html を参照してください。

FindBugs は、相対パストラバーサルの最も露骨で自明なケースだけを探します。 FindBugs が何かを見つけたならほぼ間違いなく FindBugs が報告しないより多くの脆弱性があるでしょう。 相対パストラバーサルを心配するなら、商用の静的解析ツールかペネトレーションテストツールの使用を真剣に検討するべきです。

]]>
サーブレットの絶対パストラバーサル 絶対パストラバーサル。{1}
ソフトウェアは、制限されたディレクトリ内にあるべきパス名を構築するためにHTTPリクエストのパラメータを使いますが、パラメータはそのディレクトリの外にある場所に解決できる「/abs/path」のような絶対パスシーケンスを適切に無効にしていません。 詳細は、http://cwe.mitre.org/data/definitions/36.html を参照してください。

FindBugs は、相対パストラバーサルの最も露骨で自明なケースだけを探します。 FindBugs が何かを見つけたならほぼ間違いなく FindBugs が報告しないより多くの脆弱性があるでしょう。 相対パストラバーサルを心配するなら、商用の静的解析ツールかペネトレーションテストツールの使用を真剣に検討するべきです。

]]>
反射型クロスサイトスクリプティング脆弱性があるサーブレット サーブレットの出力に HTTP パラメータを直接書き込んでいます。{1}
このコードはサーブレットの出力に HTTP パラメータを直接書き込んでいます。これは反射型 XSS(クロスサイトスクリプティング) 脆弱性を可能にします。
詳細は、http://en.wikipedia.org/wiki/Cross-site_scripting を参照してください。

FindBugs は、XSS の最も露骨で自明なケースだけを探します。 FindBugs が何かを見つけたならほぼ間違いなく FindBugs が報告しないより多くの脆弱性があるでしょう。 XSS を心配するなら、商用の静的解析ツールかペネトレーションテストツールの使用を真剣に検討するべきです。

]]>
反射型クロスサイトスクリプティング脆弱性がエラーページにあるサーブレット サーブレットのエラーページに HTTP パラメータを直接書き込んでいます。{1}
このコードはサーブレットのエラーページに HttpServletResponse.sendError を使用して HTTP パラメータを直接書き込んでいます。 信頼できない入力を返すことは反射型 XSS(クロスサイトスクリプティング) 脆弱性を可能にします。
詳細は、http://en.wikipedia.org/wiki/Cross-site_scripting を参照してください。

FindBugs は、XSS の最も露骨で自明なケースだけを探します。 FindBugs が何かを見つけたならほぼ間違いなく FindBugs が報告しないより多くの脆弱性があるでしょう。 XSS を心配するなら、商用の静的解析ツールかペネトレーションテストツールの使用を真剣に検討するべきです。

]]>
反射型クロスサイトスクリプティング脆弱性がある JSP JSP の出力に HTTP パラメータを直接書き込んでいます。{1.class}
このコードはJSP の出力に HTTP パラメータを直接書き込んでいます。これは XSS(クロスサイトスクリプティング) 脆弱性を可能にします。
詳細は、http://en.wikipedia.org/wiki/Cross-site_scripting を参照してください。

FindBugs は、XSS の最も露骨で自明なケースだけを探します。 FindBugs が何かを見つけたならほぼ間違いなく FindBugs が報告しないより多くの脆弱性があるでしょう。 XSS に関して心配しているなら商用の静的解析ツールかペネトレーションテストツールの使用を真剣に検討するべきです。

]]>
Swing メソッドは AWT イベントディスパッチスレッドから呼び出す必要がある Swing メソッドの呼び出しは AWT イベントディスパッチスレッドで実行される必要があります。{1}
(From JDC Tech Tip)
に解説されているとおり、Swing のメソッド、show メソッド、setVisible メソッド、pack メソッドは、フレームのための関連したピアを作成します。 ピアの作成で、システムはイベントディスパッチスレッドを作成します。 これが問題になることがあります。なぜなら pack メソッドと validate メソッドがまだ処理中でもイベントディスパッチスレッドがリスナに通知できるからです。 この状況は、2つのスレッドが Swing コンポーネントにアクセスする可能性があり、デッドロックや、その他のスレッドに関する問題になる可能性がある重大な欠陥です。 pack メソッドの呼び出しはコンポーネントを実体化させます。実体化しているときに、イベントディスパッチスレッドがリスナへの通知を開始する可能性があります。

]]>
明らかな無限ループ 明らかな無限ループです。{1}
このループは、例外をスローする以外の方法で終了させることができないように思われます。

]]>
明らかな無限再帰ループ 明らかな無限再帰ループです。{1}
このメソッドは、無条件で自分自身を呼び出します。これはスタックオーバーフローになる無限再帰ループを示しています。

]]>
コレクションは自分自身を追加している コレクションは、自分自身を追加しています。{1}
コレクションは、自分自身を追加しています。その結果、hashCode を計算すると StackOverflowException をスローします。

]]>
配列への volatile 参照は、配列要素を volatile として扱わない {1} は、配列への volatile 参照です。配列要素は、 volatile として扱われません。
配列に volatile 参照を宣言していますが、あなたが望むものではないかもしれません。 配列への volatile 参照は、配列への参照の読み出し、書き込みは volatile として扱われますが、配列要素は volatile として扱われません。 配列要素を volatile として扱いたいのであれば、J2SE 5.0で提供された java.util.concurrent パッケージのアトミック配列クラスを使用する必要があります。

]]>
volatile フィールドへのインクリメントはアトミックではない volatile フィールド {2} をインクリメントしています。{1}
このコードはvolatile フィールドをインクリメントしています。 volatile フィールドのインクリメントはアトミックではありません。 複数のスレッドが同時にフィールドをインクリメントすると、インクリメントが失われる可能性があります。

]]>
クラスが拡張されるなら getResource の使い方は安全ではないかもしれない クラスが拡張されるなら、getResource の使い方は安全ではないかもしれません。{1}
このクラスが別のパッケージによって拡張されるなら、this.getClass().getResource(...) の呼び出しは予想外の結果をもたらす可能性があります。

]]>
戻り型が Boolean のメソッドが明示的に null を返している {1} は、戻り型が Boolean なのに明示的に null を返しています。
Boolean.TRUE、Boolean.FALSE、null を返すメソッドはいつ事故が起きてもおかしくないです。 このメソッドは、まるで論理型の値を返すかのように呼び出されます。 コンパイラは Boolean 値のオートアンボクシングを挿入します。 null 値が返されるなら NullPointerException が発生することになります。

]]>
Optional の戻り型 ((java.util.Optional または com.google.common.base.Optional)) を持つメソッドが明示的に null を返す {1} は、Optional の戻り型を持っていて、 明示的に null を返しています。
Optional の戻り型 ((java.util.Optional または com.google.common.base.Optional)) の使い方で明示的に null を返すのは設計が望ましくないことを意味します。 null 値をこのようなケースで返すことは契約違反で、多分クライアントコードを破壊するでしょう。

]]>
非 null フィールドは初期化されていない 非 null フィールド {2.name} は {1} によって初期化されていません。
フィールドは、非 null としてマークされていますが、コンストラクタで書き込まれていません。 フィールドは、コンストラクタの間、ほかの場所で初期化されるか、または使用する前に常に初期化されるかもしれません。

]]>
同じフィールドでの同期化と null チェック フィールド {2.givenClass} は、同期化して null チェックしています。{1}
フィールドは同期化しているので、おそらく null ではないと思われます。 null のフィールドを同期化すると NullPointerException がスローされるので、null チェックは無意味になります。 別のフィールドで同期化したほうがよいです。

]]>
条件テストの繰り返し 条件テストを繰り返しています。{1}
このコードには条件テストが2回、つまり、1つめの条件テストが正しいとき、2つめの条件テストが実行されます (たとえば、x == 0 || x == 0)。 多分、2つめの条件テストは何か他のことを意図しています (たとえば、x == 0 || y == 0)。

]]>
テスト 生成されたテスト警告です。{1}
このバグパターンは、新しい不完全に実装されたバグディテクタによって生成されるだけです。

]]>
テスト1 生成されたテスト警告1です。{1}
このバグパターンは、新しい不完全に実装されたバグディテクタによって生成されるだけです。

]]>
テスト2 生成されたテスト警告2です。{1}
このバグパターンは、新しい不完全に実装されたバグディテクタによって生成されるだけです。

]]>
テスト3 生成されたテスト警告3です。{1}
このバグパターンは、新しい不完全に実装されたバグディテクタによって生成されるだけです。

]]>
未知のバグパターン 未知のバグパターンです。{1}
警告が記録されたのに FindBugs はこのバグパターンの説明を見つけることができなかったので警告について説明できません。 これは FindBugs かその設定のバグの場合だけで発生させるべきです。 または解析プラグインを使用して生成されるなら、プラグインは現在ロードされていません。

]]>
空の ZIP ファイルエントリの作成 空の ZIP ファイルエントリを作成しています。{1}
このコードは putNextEntry メソッドを呼び出して、closeEntry メソッドをすぐにを呼び出しています。 これは空の ZIP ファイルエントリになります。 エントリデータは putNextEntry メソッドと closeEntry メソッドの呼び出しの間で ZIP ファイルに書き込むべきです。

]]>
空の JAR ファイルエントリの作成 空の JAR ファイルエントリを作成しています。{1}
このコードは putNextEntry メソッドを呼び出して、 closeEntry メソッドをすぐに呼び出しています。 これは空の JAR ファイルエントリになります。 エントリデータは putNextEntry メソッドと closeEntry メソッドの呼び出しの間で JAR ファイルに書き込むべきです。

]]>
疑わしい IllegalMonitorStateException のキャッチ IllegalMonitorStateException のキャッチは疑わしいです。{1}
IllegalMonitorStateException は、一般的に設計上の欠陥 (ロックを保持していないオブジェクトで wait メソッドまたは notify メソッドを呼び出す) の場合にだけスローされます。

]]>
浮動小数点精度を使用した計算をしている 浮動小数点精度を使用して計算をしています。{1}
このメソッドは、浮動小数点精度を使用して計算をしています。浮動小数点精度は非常に不正確です。 たとえば、16777216.0f + 1.0f = 16777216.0f。 その代わりに double の使用を検討してください。

]]>
フィールドへの共変配列代入 型 {2} の配列が型 {3} のフィールドに割り当てられています。
共変型の配列がフィールドに割り当てられています。 紛らわしくて、次のコードのように他の型の参照が後で配列に格納されるなら、実行時に ArrayStoreException を引き起こすことがあります。

Number[] arr = new Integer[10];
arr[0] = 1.0;

作成した配列の型またはフィールド型を変更することを検討してください。

]]>
ローカル変数への共変配列代入 型 {2} の配列が型 {3} の変数に割り当てられています。
共変型の配列がローカル変数に割り当てられています。 紛らわしくて、次のコードのように他の型の参照が後で配列に格納されるなら、実行時に ArrayStoreException を引き起こすことがあります。

Number[] arr = new Integer[10];
arr[0] = 1.0;

作成した配列の型またはローカル変数型を変更することを検討してください。

]]>
共変配列がメソッドから返される 型 {2} の配列が戻り型 {3} であるメソッドから返されます。
共変型の配列がメソッドから返されます。 呼び出し元のコードが返された配列に他の型の参照を格納しようとするなら、実行時に ArrayStoreException を引き起こすことがあります。

作成した配列の型またはメソッドの戻り型を変更することを検討してください。

]]>
おそら互換性のない要素をく共変配列に格納している 型 {2} の値を要素の型が {3} の配列に格納しています。
配列に格納していてる値の型が配列型と一致していません。 実際の配列型が宣言された変数またはフィールドの型よりも狭くなっていて、この割り当てがオリジナルの配列型を満たしていないことが解析でわかっています。 この割り当ては実行時に ArrayStoreException を引き起こすことがあります。

]]>
Cloneable を実装したクラスが clone メソッドを定義していないか、使用していない クラス {0} は、Cloneable を実装していますが、clone メソッドを定義していないか使用していません。
このクラスは、Cloneable を実装していますが、clone メソッドを定義していないか使用していません。

]]>
Cloneable を実装していないクラスが clone メソッドを定義している {0} は、Cloneable を実装していないのに clone メソッドを定義しています。
このクラスは、Cloneable を実装していないのに clone メソッドを定義しています。 これが OK (たとえば、サブクラスのクローンの実装を自分自身で制御したい場合です) という状況もありますが意図したことなのか確認してください。

]]>
clone メソッドが super.clone() を呼び出していない {1} は、super.clone() を呼び出していません。
この非 final クラスは、super.clone() を呼び出さない clone メソッドを定義しています。 クラス A がサブクラス B によって拡張され、サブクラス Bsuper.clone() を呼び出すなら、クラス Bclone メソッドは、型 A のオブジェクトを返す可能性が高いです。 これは clone のための汎用規約に違反します。

すべての clone メソッドが super.clone() を呼び出すなら Object.clone() が呼び出されることが保証され、常に正しい型のオブジェクトが返されます。

]]>
Java の後のバージョンのキーワードである識別子を使用している {1} は、変数名に {2} を使用していますが、Java の後のバージョンのキーワードです。
識別子は、Java の後のバージョンのキーワードとして予約されている単語です。 コードを Java の後のバージョンでコンパイルするためには変更する必要があります。

]]>
Java の後のバージョンのキーワードである識別子を使用している {1} は、Java のより最近のバージョンのキーワードと衝突します。
この識別子は、Java の後のバージョンのキーワードとして使われます。 このコードと API を参照するどんなコードも、Java の後のバージョンでコンパイルするためには変更する必要があります。

]]>
例外を捨てているかもしれないメソッド {1} は、{2} を捨てているかもしれません。
このメソッドは、例外を捨てているかもしれません。 一般的にキャッチした例外は何らかの方法で処理、または報告するべきです、またはメソッドからスローするべきです。

]]>
例外を無視しているかもしれないメソッド {1} は、{2} を無視しているかもしれません。
このメソッドは例外を無視しているかもしれません。 一般的に例外は何らかの方法で処理、または報告するべきです、またはメソッドからスローするべきです。

]]>
doPrivileged ブロック内で呼び出すべきメソッド {2} の呼び出しは doPrivileged ブロックの中から呼び出すべきです。{1}
このコードはセキュリティ許可チェックが必要なメソッドを呼び出しています。 このコードにセキュリティ許可が与えられるとしても、セキュリティ許可を持たないコードによって呼び出されるなら doPrivileged ブロックの中で呼び出す必要があります。

]]>
Method invoked that should be only be invoked inside a doPrivileged block invocation of {2}, which should be invoked from within a doPrivileged block, in {1}
This code invokes a method that requires a security permission check. If this code will be granted security permissions, but might be invoked by code that does not

]]>
doPrivileged ブロック内で作成されるべきクラスローダ {1} は、doPrivileged ブロックの中でクラスローダ {2} を作成するべきです。
このコードはクラスローダを作成していますが、セキュリティ管理がインストールされるなら許可が必要です。 このコードがセキュリティ許可がないコードによって呼び出されるなら、クラスローダの作成は doPrivileged ブロックの中で行う必要があります。

]]>
不変クラスのフィールドは final にすべき {0} は不変とマークされているので、{1.givenClass} は final にすべきです。
クラスは、net.jcip.annotations.Immutable または javax.annotation.concurrent.Immutable でアノテートされています。 アノテーションのルールは、すべてのフィールドが final であることを義務づけます。

]]>
Thread オブジェクトが Runnable が期待されているところに渡されている Thread オブジェクトが Runnable が期待されているところに渡されています。{1}
Threadオブジェクトが Runnable が期待されているメソッドへのパラメータとして渡されています。 これはかなり異常で、論理エラーを示すか、予想外の振る舞いの原因になることがあります。

]]>
URL の Map や Set はひどい性能になる {1} は、URL の Map か Set を使用しているので、ひどい性能になります。
このメソッドまたはフィールドは、URL の MapSet を使用しています。 URL の equalshashCode は、ドメイン名の解決を行うので、ひどい性能になります。
詳細は、http://michaelscharf.blogspot.com/2006/11/javaneturlequals-and-hashcode-make.html を参照してください。
その代わりに java.net.URI を使用することを検討してください。

]]>
URL の equals メソッドと hashCode メソッドはブロックする {2} の呼び出しはドメイン名解決のためにブロックします。{1}
URL の equals メソッドと hashCode メソッドは、ドメイン名の解決を行うので、ひどい性能になる可能性があります。
詳細は、http://michaelscharf.blogspot.com/2006/11/javaneturlequals-and-hashcode-make.html を参照してください。
その代わりに java.net.URI を使用することを検討してください。

]]>
ランタイムリテンションなしで、アノテーションの存在を調べるためにリフレクションを使用することはできない ランタイムリテンションを持たないアノテーション {3} の存在を調べるためにリフレクションを使用しています。{1}
アノテーションは、@Retention(RetentionPolicy.RUNTIME) でアノテートされなければ、リフレクション (たとえば、isAnnotationPresent(...) メソッド) を使用して観測することができません。

]]>
System.exit(...) を呼び出しているメソッド {1} は、System.exit(...) を呼び出しています。これは Java 仮想マシン全体をシャットダウンさせてしまいます。
System.exit(...) を呼び出すことは、Java 仮想マシン全体をシャットダウンさせてしまいます。 それが適切な場合にだけ使用するべきです。 System.exit(...) の呼び出しは、他のコードによる呼び出しを困難か不可能にします。 その代わりに RuntimeException をスローすることを検討してください。

]]>
危険なメソッド runFinalizersOnExit を呼び出しているメソッド {1} は、危険なメソッド runFinalizersOnExit を呼び出しています。
どんな理由があるにせよ決して System.runFinalizersOnExitRuntime.runFinalizersOnExit を呼び出さないでください。 Java ライブラリで最も危険なメソッドの1つです。 -- Joshua Bloch

]]>
効率が悪い new String(String) コンストラクタを呼び出しているメソッド {1} は、効率が悪い new String(String) コンストラクタを呼び出しています。
new String(String) コンストラクタの使用はメモリを浪費します。 そのようにして構築されたオブジェクトと パラメータとして渡された String は機能的に区別がつかないからです。 引数の String をそのまま使用してください。

]]>
効率が悪い new String() コンストラクタを呼び出しているメソッド {1} は、効率が悪い new String() コンストラクタを呼び出しています。
引数がないコンストラクタを使用して、新しい java.lang.String() オブジェクトを作成するとメモリを浪費します。 そのようにして作成されたオブジェクトと空の文字列定数 "" は機能的に区別がつかないからです。 Javaは、同一の文字列定数が同じ String オブジェクトによって表されることを保証します。 したがって、直接空の文字列定数を使用するべきです。

]]>
String の toString メソッドを呼び出しているメソッド {1} は、String の toString メソッドを呼び出しています。
String.toString() を呼び出すのは冗長です。String を使用してください。

]]>
明示的なガベージコレクション {1} は、ガベージコレクションを強制しています。ベンチマークコードを除いて非常に疑わしいです。
明示的にガベージコレクションを呼び出しています。ベンチマークの特定の用途を除いて非常に疑わしいです。

過去に、close メソッドや finalize メソッドでガベージコレクタを明示的に呼び出していた状況は、巨大なパフォーマンスブラックホールの原因となりました。 ガベージコレクションは高くつきます。何百、何千ものガベージコレクションを強制する状況は、システムの停滞をもたらすでしょう。

]]>
効率が悪い Boolean コンストラクタを呼び出しているメソッド {1} は、効率が悪い Boolean コンストラクタを呼び出しています。その代わりに Boolean.valueOf(...) を使用してください。
java.lang.Boolean の新しいインスタンスを作成するとメモリを浪費します。 Boolean オブジェクトは不変で、2つの有用な値 (Boolean.TRUEBoolean.FALSE) があります。 その代わりに Boolean.valueOf メソッド (または J2SE 5.0 のオートボクシング) を使用して Boolean オブジェクトを作成してください。

]]>
効率が悪い Number コンストラクタを呼び出しているメソッド {1} は、効率が悪い {2} コンストラクタを呼び出しています。その代わりに {3} を使用してください。
new Integer(int) の使用は、常に新しいブジェクトになることが保証されています。 これに対して、Integer.valueOf(int) は、コンパイラ、クラスライブラリ、Java 仮想マシンで値がキャッシュされます。 キャッシュに格納された値を使用することはインスタンスの作成を回避し、コードはより高速になります。

-128から127までの値は対応するキャッシュされたインスタンスを持つことが保証されています。 そして、valueOf メソッドの使用は、コンストラクタを使用するより約3.5倍高速です。 定数範囲外の値は、両方のスタイルの性能は同じです。

クラスが J2SE 5.0より前の Java 仮想マシンとの互換性が不要なら、LongIntegerShortCharacterByte のインスタンスを作成するときは、オートボクシングか valueOf メソッドを使用してください。

]]>
効率が悪い浮動小数点 Number コンストラクタを呼び出しているメソッド {1} は、効率が悪い {2} コンストラクタを呼び出しています。その代わりに {3} を使用してください。
new Double(double) の使用は、常に新しいブジェクトになることが保証されています。 これに対して、Double.valueOf(double) は、コンパイラ、クラスライブラリ、Java 仮想マシンで値がキャッシュされます。 キャッシュに格納された値を使用することはインスタンス生成を回避し、コードはより高速になります。

クラスが J2SE 5.0より前の Java 仮想マシンとの互換性が不要なら、オートボクシングか DoubleFloatvalueOf メソッドを使用してください。

]]>
呼び出したメソッドの Locale パラメータの使用を検討する ローカライズされていない String.toUpperCase() または String.toLowerCase() を使用しています。{1}
文字列がプラットホームのデフォルトエンコーディングを使用して大文字、小文字に変換されています。 国際文字で使われると不適切な変換になることがあります。

  • String.toUpperCase(Locale l)
  • String.toLowerCase(Locale l)
]]>
プリミティブ値が3項演算子のためにアンボクシングされて、型変換される プリミティブ型の値が3項演算子のためにアンボクシングされて、型変換されます。{1}
ラップされたプリミティブ値は、3項演算子 ( b ? e1 : e2) の評価の一部として、別のプリミティブ型にアンボクシングされて変換されます。 Java 言語仕様では、e1e2 がラップされた数値なら値はアンボクシングされ、共通の型へと変換/型変換されます (たとえば、e1Integer で、e2Float なら e1 はアンボクシング (int に変換) され、float に変換され、ボクシング (Float に変換) されます)。 JLS セクション15.25を参照してください。

]]>
プリミティブ値がボクシングされて、すぐにアンボクシングされる プリミティブ値がボクシングされて、すぐにアンボクシングされます。{1}
プリミティブ値がボクシングされて、すぐにアンボクシングされます。 おそらくアンボクシングされた値が必要な場所で手動でボクシングをしているためです。 その結果、コンパイラにボクシングの機能を取り消すことを強制しています。

]]>
ボクシングされた値がアンボクシングされて、すぐに再ボクシングされる ボクシングされた値がアンボクシングされて、すぐに再ボクシングされます。{1}
ボクシングされた値がアンボクシングされて、すぐに再ボクシングされます。

]]>
プリミティブ値がプリミティブ型の型変換をするためにボクシングされて、アンボクシングされる プリミティブ値がプリミティブ型の型変換をするためにボクシングされて、アンボクシングされます。{1}
プリミティブ値がコンストラクタでボクシングされて、すぐに異なるプリミティブ型に変換されます (たとえば new Double(d).intValue())。 直接プリミティブ型の型変換を実行してください (たとえば (int) d)。

]]>
toString メソッドを呼び出すためにプリミティブ型のラッパクラスのインスタンスを作成している toString メソッドを呼び出すためにプリミティブ型のラッパクラスのインスタンスを作成しています。{1}
toString メソッドを呼び出すためにプリミティブ型のラッパクラスのインスタンスを作成しています。 それよりもプリミティブ値を引数にとる static な toString メソッドを使用したほうが効率的です。

置換前置換後
new Integer(1).toString()Integer.toString(1)
new Long(1).toString()Long.toString(1)
new Float(1.0).toString()Float.toString(1.0)
new Double(1.0).toString()Double.toString(1.0)
new Byte(1).toString()Byte.toString(1)
new Short(1).toString()Short.toString(1)
new Boolean(true).toString()Boolean.toString(true)
]]>
ボクシング/アンボクシングはプリミティブを解析する ボクシング/アンボクシングは、プリミティブ {1} を解析しています。
ボックス化されたプリミティブは、String から生成されていて、アンボックス化されたプリミティブ値を抽出します。 static parseXXX メソッドを呼び出す方が効率的です。

]]>
プリミティブが比較でボクシングされている プリミティブが {2} を呼び出すためにボクシングされています: 代わりに {3} を使用してください。
ボクシングされたプリミティブが単に compareTo メソッドを呼び出すために作られています。 直接プリミティブで働く static compare メソッド (double と float は Java 1.4から、他のプリミティブ型は Java 1.7から) を使うほうがより効率的です。

]]>
クラスオブジェクトを得るためだけにインスタンスを作成しているメソッド {1} は、クラスオブジェクトを得るためだけにインスタンスを作成しています。
メソッドは、クラスオブジェクトを得るためにインスタンスを生成して getClass メソッドを呼び出しています。 クラスリテラル (Foo.class) を使うほうが簡単です。

]]>
Condition で wait メソッドを呼び出している Condition で wait メソッドを呼び出しています。{1}
このメソッドは、java.util.concurrent.locks.Condition オブジェクトで wait メソッドを呼び出しています。 Condition オブジェクトを待機させるためには Condition インタフェースで定義された await メソッドを使用するべきです。

]]>
0から1の乱数値は整数値0に丸められる {1} は、0から1の乱数値を生成していますが、整数値0に丸められます。
0から1の乱数値は整数値0に丸められます。 おそらく整数に丸められる前に何か他のことによって乱数値を倍数にしたかったか、または Random.nextInt(n) メソッドを使いたかったのでしょう。

]]>
Math.max と Math.min の間違った組み合わせ Math.max と Math.min の組み合わせが間違っています: このコードは常に {2} を返します。
このコードは Math.min(0, Math.max(100, value)) のような構文を使用して境界値を制限しようとしています。 しかしながら、定数の順序が間違っています。 Math.min(100, Math.max(0, value)) とすべきです。 結果としてこのコードは常に同じ結果 (もし値が NaN なら NaN) を作り出します。

]]>
Incorrect combination of Math.max and Math.min Incorrect combination of Math.max and Math.min: this code always returns {2}
This code tries to limit the value bounds using the construct like Math.min(0, Math.max(100, value)). However the order of the constants is incorrect: it should be Math.min(100, Math.max(0, value)). As the result this code always produces the same result (or NaN if the value is NaN).

]]>
整数の乱数を生成するためには nextDouble メソッド ではなく nextInt メソッドを使用する {1} は、整数の乱数を生成するために nextDouble メソッドを使用しています。nextInt メソッドを使用した方が効率的です。
java.util.Random のインスタンス r で、0 から n-1 の乱数を生成したいのであれば、(int)(r.nextDouble() * n) ではなく r.nextInt(n) を使用します。

nextInt メソッドへの引数は整数でなければなりません。 たとえば、-99から0までの乱数を生成したいなら、-r.nextInt(100) を使用してください。

]]>
SQL の Statement の execute または addBatch メソッドに定数でない文字列を渡している {1} は、SQL の Statement の execute または addBatch メソッドに定数でない文字列を渡しています。
このメソッドは、動的に生成されるように思われる文字列で、 SQL 文 の execute または addBatch メソッドを呼び出しています。 その代わりに PreparedStatement を使用することを検討してください。 効率的で、SQL インジェクション攻撃に強いです。

]]>
PreparedStatement が定数でない文字列から生成されている PreparedStatement が定数でない文字列から生成されています。{1}
このコードは定数でない文字列から SQL の PreparedStatement を作成しています。 ユーザからのチェックされていない汚染されたデータがこの文字列を作る際に使われるなら、PreparedStatement で予想外で望ましくない何かをするために SQL インジェクションが使われる可能性があります。

]]>
デフォルトの空の run メソッドを使用して作成されたスレッド {1} は、デフォルトの空の run メソッドを使用してスレッドを作成しています。
このメソッドは、Thread クラスから派生した run メソッドを指定していないか、Runnable オブジェクトを渡すことなく、スレッドを作成しています。 このスレッドは、時間の無駄です。

]]>
フィールドのダブルチェックの可能性 フィールド {2} のダブルチェックをしている可能性があります。{1}
このメソッドにはダブルチェックロッキングのインスタンスがあるかもしれません。このイディオムは、Java のメモリモデルでは正しくありません。
詳細は、http://www.cs.umd.edu/~pugh/java/memoryModel/DoubleCheckedLocking.html を参照してください。

]]>
部分的に初期化されたオブジェクトを暴露する可能性がある 部分的に初期化されたオブジェクトを暴露する可能性があります。{1}
ダブルチェックロッキングと共に遅延初期化フィールドを使用するメソッドのようです。 フィールドが正しく volatile として宣言される間にオブジェクトの内部構造がフィールドに割り当てられた後で変更される可能性があります。 したがって、他のスレッドが部分的に初期化されたオブジェクトを見るかもしれません。

この問題を直すために、最初にローカル変数をオブジェクトに格納して、完全に構築した後で volatile フィールドを保存することを考えてください。

]]>
ファイナライザはフィールドを null にする {3} は、finalize メソッドの中で null を設定しています。{1.class}
このファイナライザは、フィールドを null にしています。 これは通常誤りでガベージコレクタを助けません。オブジェクトはいずれにしろガベージされます。

]]>
ファイナライザはフィールドを null にするだけ {1} は、フィールドを null にするだけです。
このファイナライザは、フィールドを null にすること以外に何もしません。 これはまったく無意味であり、オブジェクトがガベージされ、ファイナライズされ、再びガベージされることを要求しています。 finalize メソッドを除去するべきです。

]]>
ファイナライザは public ではなく protected にすべき {1} は public です。protected にすべきです。
このクラスの finalize メソッドは public ではなく、protected にすべきです。

]]>
空のファイナライザは削除するべき {1} は、空なので削除するべきです。
空の finalize メソッドは役に立たないので削除するべきです。

]]>
ファイナライザはスーパークラスのファイナライザを無効にしている {1} は、{2}.finalize() を無効にしています。これは意図したことですか?
この空の finalize メソッドは、明示的にスーパークラスによって定義されたどんなファイナライザの効果も無効にします。 スーパークラスのために定義されたどんなファイナライザアクションも実行されません。 これが意図したことではない場合、メソッドを削除してください。

]]>
ファイナライザはスーパークラスのファイナライザを呼び出しているだけ {1} は、super.finalize() を呼び出す以外何もしないので、削除してください。
この finalize メソッドは、スーパークラスの finalize メソッドを呼び出しているだけです。 冗長なので削除してください。

]]>
ファイナライザはスーパークラスのファイナライザを呼び出していない {1} は、super.finalize() への呼び出しが見つからないので、{2}.finalize() は呼び出されません。
この finalize メソッドは、スーパークラスの finalize メソッドを呼び出していません。 したがって、スーパークラスのために定義されたどんなファイナライザアクションも実行されません。 super.finalize() の呼び出しを追加してください。

]]>
ファイナライザの明示的な呼び出し {1} は、明示的に {2} を呼び出しています。
このメソッドには明示的にオブジェクトで finalize メソッドの呼び出しがあります。 ファイナライザは Java 仮想マシンによって1度だけ実行されることになっているので、これは間違った考えです。

参照によってつながった複数のオブジェクトがファイナライズ可能になると、Java 仮想マシンはすべてのオブジェクトの finalize メソッドを呼び出します。 おそらく異なるスレッドで同時にです。 したがって、クラス Xfinalize メソッドの中から X によって参照されているオブジェクトの finalize メソッドを呼び出すのは、とりわけ間違った考えです。 なぜなら、オブジェクトが既に別のスレッドによってファイナライズされているかもしれないからです。

]]>
equals メソッドは互換性のないオペランドをチェックしている {1} は、{2.givenClass} であるオペランドをチェックしています。
この equals メソッドは、引数が互換性のない型 (すなわちスーパタイプでもなく、equals メソッドを定義しているクラスのスーパータイプでもサブタイプでもないクラス) なのか確かめています。 たとえば、Foo クラスの equals メソッドはそのように見えるかもしれません。

public boolean equals(Object o) {
    if (o instanceof Foo)
        return name.equals(((Foo)o).name);
    else if (o instanceof String)
        return name.equals(o);
    else return false;
}

これは対称的で推移的である equals メソッドを実現するのはとても難しいので、バッドプラクティスと見なされています。 プロパティがなければまったく予想していない振る舞いが起こりえます。

]]>
列挙型は共変な equals メソッドを定義している 列挙型 {0} は、equals({0.givenClass}) を定義しています。
このクラスは列挙を定義していて、列挙の等価性はオブジェクト同一性を使用して定義されています。 列挙値のために共変な equals メソッドを定義することは、ひどいバッドプラクティスです。 2つの異なる列挙値が equals メソッドでは「等価ではない」と判定され、共変な equals メソッドでは「等価」と判定されるからです。 共変な equals メソッドを定義しないでください。

]]>
共変な equals メソッドを定義して、Object.equals(Object) を継承している {0} は、equals({0.givenClass}) メソッドを定義して、Object.equals(Object) を使用しています。
このクラスは、共変な equals メソッドを定義していますが、 equals(Object) メソッドは java.lang.Object クラスから継承しています。 クラスは、boolean equals(Object) メソッドを定義するべきです。

]]>
Object.equals(Object) をオーバーライドしていない equals メソッドの定義 {0}は、{1.givenClass} メソッドを定義して、Object.equals(Object) を使用しています。
このクラスは、equals メソッドを定義していますが、java.lang.Object クラスの equals(Object) メソッドをオーバーライドしていません。 クラスは、boolean equals(Object) メソッドを定義するべきです。

]]>
equals(Object) メソッドをオーバーライドしていない equals メソッドの定義 {0} は、equals(Object) メソッドをオーバーライドしない {1.givenClass} を定義しています。
このクラスは、equals メソッドを定義していますが、java.lang.Object クラスの equals(Object) メソッドをオーバーライドしていません。 その代わりに、スーパークラスから equals(Object) メソッドを継承して、boolean equals(Object) メソッドを定義するべきです。

]]>
スーパークラスの equals メソッドをオーバーライドしていないクラス {0} は、{2.givenClass} をオーバーライドしていません。
このクラスは、equals メソッドを定義しているクラスを拡張してフィールドを追加していますが、equals メソッドを定義していません。 したがって、このクラスのインスタンスの等価性は、サブクラスと追加されたフィールドの同一性を無視します。 これが意図したことで、しかも、equals メソッドをオーバーライドする必要がないことを確実にしてください。 たとえ equals メソッドをオーバーライドする必要がないとしても、サブクラスのための equals メソッドが super.equals(o) を呼び出して結果を返すという事実を実証するためにいずれにしろ、equals メソッドをオーバーライドすることを検討してください。

]]>
共変な equals メソッドの定義 {0} は、equals({0.givenClass}) メソッドを定義していますが、equals(Object) を定義していません。
このクラスは、共変な equals メソッドを定義しています。 java.lang.Objectequals メソッドを正しくオーバーライドするためには equals メソッドのパラメータの型は、java.lang.Object でなければなりません。

]]>
equals メソッドはスーパークラスの equals メソッドをオーバーライドしているが、対称的ではないかもしれない {1.class} は、{2.class.givenClass} で equals メソッドをオーバーライドしていますが、対称的ではないかもしれません。
このクラスはスーパークラスの equals メソッドをオーバーライドする equals メソッドを定義しています。 両方の equals メソッドは、2つのオブジェクトが等しいかどうかの判定で、instanceof を使用しています。 equals メソッドは対称的 (a.equals(b) == b.equals(a)) であることが重要なのでこれは危険を伴っています。 BA のサブタイプなら Aequals メソッドは引数が instanceof A なのかチェックします。 そして、Bequals メソッドは引数が instanceof B なのかチェックします。 これらのメソッドによって定義された同値関係が対称的でないということです。

]]>
equals メソッドはサブタイプのために失敗する {1} は、サブタイプのために失敗します。
このクラスは、サブクラスによる継承によって壊れる equlas メソッドがあります。 equals メソッドは、クラスリテラルを引数のクラスと比較しています (たとえば、Foo クラスで Foo.class == o.getClass() のような判定を行っています)。 this.getClass() == o.getClass() の方がより良いです。

]]>
異常な equals メソッド {1} は、異常な equals メソッドです。
このクラスの equals メソッドは、引数の型が this オブジェクトの型と互換性があるこをチェックするために我々が認識しているパターンで何もしていません。 このコードは何も間違っていないかもしれませんが、レビューする価値があります。

]]>
equals メソッドはクラスオブジェクトではなくクラス名を比較している {1} は、クラスオブジェクトではなく、クラス名を比較しています。
このメソッドは、クラス名を比較することによって、2つのオブジェクトが同じクラスなのか確かめています。 異なるクラスローダによってロードされたクラスなら、同じ名前で異なるクラスがある可能性があります。 クラスオブジェクトが同じなのか確かめてください。

]]>
equals メソッドは常に true を返す {1} は、常に true を返します。
このクラスは、常に true を返す equals メソッドを定義しています。 これは想像力に富むが、あまり良い方法とはいえません。さらに、equals メソッドが対称的ではないことを意味します。

]]>
equals メソッドは常に false を戻す {1} は、常に false を返します。
このクラスでは、常に false を返す equlas メソッドを定義しています。 これはオブジェクトがそれ自身と等価ではないことを意味していて、このクラスの有用な Map や Set を作成できません。 より根本的に、equals メソッドの要件の一つである反射性を満たしていないことになります。

おそらく意図されたことは、オブジェクトはそれ自身と等価であるというオブジェクト同一性です。 これは Object クラスから継承される振る舞いです。 異なるスーパークラスから継承される equals メソッドをオーバーライドする必要があるなら以下のようなコードが使えます。

public boolean equals(Object o) {
    return this == o;
}
]]>
複数のクラスファイルにわたって複製されている巨大な文字列定数 長さが {2} 文字の文字列定数 {1} が {3} つのクラスファイルに複製されています。
巨大な文字列定数が複数のクラスファイルにわたって複製されています。 final フィールドが文字列定数で初期化され、Java 言語によって他のクラスからの final フィールドへのすべての参照がクラスファイルにインライン化されるからです。

JDK はこのバグを解決してサイズを1MB減らすことができました。
詳細は、JDK bug 6447475 を参照してください。

]]>
null の引数をチェックしていないメソッド {1} は、null の引数をチェックしていません。
このメソッドへのパラメータが null かどうか確かめるために常にチェックされるべき値として特定されました。 しかし、null チェックをしないで、null 値が利用されています。

]]>
equals メソッドは null の引数をチェックしていない {1} は、null の引数をチェックしていません。
この equals(Object) メソッドの実装は引数として渡されている null をチェックしていないので、java.lang.Object.equals() で定義された規約に違反しています。 すべての equals メソッドは引数に null が渡されたなら false を返すべきです。

]]>
compareTo()/compare() の結果を無効にする {1} は、{2} の戻り値を無効にします。
このコードは compareTo または compare メソッドの戻り値を無効にしています。 これは疑わしいかバッドプログラミングプラクティスです。戻り値が Integer.MIN_VALUE なので、戻り値を無効にすることは結果の符号を無効にしません。 結果を無効にするのではなくオペランドの順序を逆にすることによって、同じ意図した結果を得ることができます。

]]>
compareTo()/compare() は Integer.MIN_VALUE を返す {1} は Integer.MIN_VALUE を返します。戻り値を無効にできません。
いくつかの状況下では、この compareTo または compare メソッドは Integer.MIN_VALUE を返します。ひどいバッドプラクティスです。 compareTo メソッドの戻り値で重要なことは結果の符号だけです。 しかし、結果の符号を無効にすることを期待して、compareTo メソッドの戻り値を無効にすることがあります。 返された値が Integer.MIN_VALUE の場合を除いてです。 Integer.MIN_VALUE よりも-1を返してください。

]]>
compareTo()/compare() は間違って float または double 値を処理する {1} は、間違って {2} 値を処理します。
このメソッドはこのようなパターンを使用して double または float 値を比較しています : val1 > val2 ? 1 : val1 < val2 ? -1 : 0。 このパターンは 正しくないソート結果や壊れたコレクションの原因になるかもしれない -0.0 や NaN 値のために間違って働きます (もし比較された値がキーとして使われるなら)。 すべての特殊なケースを正確に処理するために Double.compare または Float.compare メソッドの使用を検討してください。

]]>
共変な compareTo メソッドの定義 {0} は、compareTo(Object) ではなく compareTo({0.givenClass}) メソッドを定義しています。
このクラスは、共変な compareTo メソッドを定義しています。 Comparable インタフェースの compareTo メソッドを正しく実装するためには compareTo メソッドのパラメータの型は、java.lang.Object でなければなりません。

]]>
ハッシュ化された文脈でハッシュ化できないクラスの使用がシグネチャで宣言されている {2} は、hashCode メソッドを定義していないのにハッシュ化された文脈で使われています。{1}
メソッド、フィールド、クラスは、ハッシュ可能なクラスが必要な文脈で、ハッシュ化できないクラスが使用される総称的なシグネチャを宣言しています。 クラスは、equals メソッドを宣言していますが、hashCode メソッドは java.lang.Object から継承しています。 これは「等価なオブジェクトは等価なハッシュコードを保持する必要がある」という hashCode メソッドの汎用規約に従っていないのでハッシュ化できません。

]]>
ハッシュデータ構造で hashCode メソッドのないクラスを使用している {2} は、hashCode メソッドを定義していないのにハッシュデータ構造で使われています。{1}
このクラスは、equals(Object) メソッドを定義していますが、hashCode メソッドを定義していません。 これは「等価なオブジェクトは等価なハッシュコードを保持する必要がある」という hashCode メソッドの汎用規約に従っていません。 このクラスのインスタンスはハッシュデータ構造で使われています。最重要問題を修正する必要があります。

]]>
hashCode メソッドを定義して Object.equals() を使用しているクラス {0} は、hashCode メソッドを定義して、Object.equals() を使用しています。
このクラスは、hashCode メソッドを定義していますが、 equals メソッドは java.lang.Object から継承しています (オブジェクトの参照比較で等価性を判定します)。 これは「等価なオブジェクトは等価なハッシュコードを保持する必要がある」という hashCode メソッドの汎用規約に従っているかもしれませんが、 おそらく、hashCode メソッドをオーバーライドすることによって意図されたことではありません。 (hashCode メソッドをオーバーライドすることは、オブジェクトの同一性が単純な参照等価性よりも複雑な規約に基づくことを意味します)。

このクラスのインスタンスが HashMap/HashTable に決して代入されるだろうと思わないなら推奨される hashCode メソッドの実装は以下のようになります。

public int hashCode() {
    assert false : "hashCodeが呼び出されることは想定されていません。";
    return 42; // 適当な値 
}
]]>
compareTo(...) メソッドを定義して Object.equals() を使用しているクラス {0} は、{1.givenClass} を定義して、Object.equals() を使用しています。
このクラスは、compareTo(...) メソッドを定義していますが、equals メソッドは java.lang.Object から継承しています。 一般的にequals メソッドが true を返す場合に限り、compareTo メソッドは0を返すべきです。 これが違反されるなら奇妙で予測できない失敗が PriorityQueue などのクラスで発生します。 J2SE 5.0では、PriorityQueue.remove()compareTo メソッドを使用しますが、Java SE 6では、equals メソッドを使用します。

Comparable インタフェースの compareTo メソッドの JavaDoc を以下に引用します。

必須というわけではありませんが、(x.compareTo(y)==0) == (x.equals(y)) であることが強く推奨されます。 一般的にComparable インタフェースを実装しているクラスで、この条件に違反するクラスは明確にこの事実を示す必要があります。 「注:このクラスは equals と一貫性のない自然順序付けを持ちます」などと明示することをお勧めします。

]]>
hashCode メソッドを定義していますが equals メソッドは定義していないクラス {0} は、hashCode メソッドを定義していますが、equals メソッドは定義していません。
このクラスは、hashCode メソッドを定義していますが、equals メソッドは定義していません。 これは「等価なオブジェクトは等価なハッシュコードを保持する必要がある」という hashCode メソッドの汎用規約に違反するかもしれません。

]]>
equals メソッドを定義して Object.hashCode() を使用しているクラス {0} は、equals メソッドを定義して、Object.hashCode() を使用しています。
このクラスは、equals(Object) をオーバーライドしていますが、hashCode メソッドは java.lang.Object から継承しています (同一性ハッシュコード (Java 仮想マシンによってオブジェクトに代入された任意の値) を返します)。 したがって、「等価なオブジェクトは等価なハッシュコードを保持する必要がある」という hashCode メソッドの汎用規約に違反するかもしれません。

このクラスのインスタンスが HashMap/HashTable に決して代入されるだろうと思わないなら推奨される hashCode メソッドの実装は以下のようになります。

public int hashCode() {
    assert false : "hashCodeが呼び出されることは想定されていません。";
    return 42; // 適当な値 
}
]]>
equals メソッドを継承して Object.hashCode() を使用しているクラス {0} は、equals メソッドを継承して、Object.hashCode() を使用しています。
このクラスは、抽象スーパークラスから equals(Object) メソッドを継承して、java.lang.Object から hashCode メソッドを継承しています (同一性ハッシュコード (Java 仮想マシンによってオブジェクトに代入された任意の値) を返します)。 したがって、「等価なオブジェクトは等価なハッシュコードを保持する必要がある」という hashCode メソッドの汎用規約に違反するかもしれません。

hashCode メソッドを定義したくないまたはオブジェクトが HashMap/Hashtable に決して格納されないだろうと思っているなら UnsupportedOperationException をスローする hashCode() メソッドを定義してください。

]]>
equals メソッドは定義していますが hashCode メソッドは定義していないクラス {0} は、equals メソッドを定義していますが、hashCode メソッドは定義していません。
このクラスは、equals(Object) メソッドをオーバーライドしていますが、hashCode メソッドはオーバーライドしていません。 したがって、「等価なオブジェクトは等価なハッシュコードを保持する必要がある」という hashCode メソッドの汎用規約に違反するかもしれません。

]]>
抽象クラスは共変な equals メソッドを宣言している 抽象クラス {0} は、共変な equals({0.givenClass}) メソッドを定義しています。
このクラスは、共変な equals メソッドを定義しています。 java.lang.Objectequals メソッドを正しくオーバーライドするためには equals メソッドのパラメータの型は、java.lang.Object でなければなりません。

]]>
String オブジェクトを == や != を使用して比較している String オブジェクトを == や != を使用して比較しています。{1}
このコードは参照等価性のために == や != を使用して java.lang.String オブジェクトを比較しています。 両方の文字列がソースファイルの定数か、String.intern() を使用して正準化されていないかぎり、同じ文字列は2つの異なる String オブジェクトによって表されるかもしれません。 その代わりに equals(Object) メソッドを使用することを検討してください。

]]>
String パラメータを == や != を使用して比較している String パラメータを == や != を使用して比較しています。{1}
このコードは参照等価性のために == や != を使用して java.lang.String パラメータを比較しています。 文字列定数または正準化された文字列だけをメソッドに渡すことを呼び出し元に要求することは必要以上に脆弱で測定可能な性能の向上をもたらしません。 その代わりに equals(Object) メソッドを使用することを検討してください。

]]>
抽象クラスは共変な compareTo メソッドを定義している 抽象クラス {0} は、compareTo({0.givenClass}) メソッドを定義しています。
このクラスは、共変な compareTo メソッドを定義しています。 Comparable インタフェースの compareTo メソッドを正しく実装するためには compareTo メソッドのパラメータの型は、java.lang.Object でなければなりません。

]]>
並行アクセスに対してガードされていないフィールド {1.givenClass} は、並行アクセスに対してガードされていません。{2}% の時間をロック
このフィールドは、net.jcip.annotations.GuardedBy または javax.annotation.concurrent.GuardedBy でアノテートされていますが、アノテーションに違反すると思われる方法でアクセスできます。

]]>
可変サーブレットフィールド {1} は、可変サーブレットフィールドです。
Web サーバは、一般的にサーブレットや JSP クラスのインスタンスを1つだけ作成します (すなわち、シングルトンとして扱います)。 複数のスレッドが複数同時のリクエストに応えるためにそのインスタンスでメソッドを呼び出します。 したがって、一般に可変インスタンスフィールドは競合状態を作ります。

]]>
一貫性のない同期化 {1} の一貫性のない同期化です。{2}% の時間をロック
このクラスのフィールドは、同期化に関して一貫性なくアクセスされるように見えます。 このバグレポートは、バグパターンディテクタが以下のように判断したことを示します。

  • クラスは、ロックされたアクセスとアンロックされたアクセスが混在していて
  • クラスは、javax.annotation.concurrent.NotThreadSafe としてアノテートされません
  • 少なくとも1つのロックされたアクセスがクラス自身のメソッドの1つによって実行され、
  • 読み出しの2倍の重み付けをした書き込みで、非同期フィールドのアクセス (読み出しと書き込み) 数がすべてのアクセスのわずか1/3

このバグパターンに合致する典型的なバグは、スレッドセーフを意図したクラスでメソッドを同期化させることを忘れていることです。

ディテクタがどこでフィールドが同期化なしでアクセスされると信じていたかを示すコードの場所に「非同期アクセス」というラベルがついているノードを選択できます。

不正確ないろいろな原因がこのディテクタにあることに注意してください。 たとえば、ディテクタはロックを保持されるすべての状況を静的に検出できるわけではありません。 また、ディテクタがロックされたアクセスとアンロックされたアクセスの区別が正確なときでも、問題のコードは依然として正しいかもしれません。

]]>
裸の notify メソッド {1} の中に裸の notify メソッドがあります。
notify メソッドまたは notifyAll メソッドへの呼び出しは可変オブジェクト状態にどんな (明らかな) 付随的な変更ももたらされませんでした。 一般的に別のスレッドが期待しているいくつかの条件が真になったので、モニタで notify メソッドが呼び出されます。 しかしながら、意味がある条件のために両方のスレッドに見えるヒープオブジェクトを含まなければなりません。

可変オブジェクトの状態変更が通知があるメソッドを呼び出したメソッドで起こったかもしれないので、このバグが必ずしもエラーを示すというわけではありません。

]]>
配列を返すことによって内部表現を暴露するかもしれない public static メソッド {1} は、 {2.givenClass} を返すことによって、内部表現を暴露するかもしれません。
public static メソッドは、クラスの 静的な状態の一部である配列の参照を返します。 このメソッドを呼び出すどんなコードも、基底配列を自由に変更できます。 解決策は、配列のコピーを返すことです。

]]>
可変オブジェクトへの参照を返すことによって内部表現を暴露するかもしれないメソッド {1} は、{2.givenClass} を返すことによって内部表現を暴露するかもしれません。
オブジェクトのフィールドに格納された可変オブジェクトの参照を返すと、オブジェクトの内部表現を暴露します。 インスタンスが信頼できないコードによってアクセスされるなら、可変オブジェクトのチェックされていない変更がセキュリティや他の重要なプロパティを危うくするでしょう。 何か違うことをする必要があります。オブジェクトの新しいコピーを返すことは、多くの状況でより良いアプローチです。

]]>
可変オブジェクトへの参照を取り込むことによって内部表現を暴露するかもしれないメソッド {1} は、{2.givenClass} の中に外部の可変オブジェクトを格納することによって内部表現を暴露するかもしれません。
このコードはオブジェクトの内部表現に外部の可変オブジェクトの参照を格納しています。 インスタンスが信頼できないコードによってアクセスされるなら、可変オブジェクトのチェックされていない変更がセキュリティや他の重要なプロパティを危うくするでしょう。 何か違うことをする必要があります。オブジェクトの新しいコピーを返すことは、多くの状況でより良いアプローチです。

]]>
static フィールドに可変オブジェクトを格納することによって、内部の静的状態を暴露するかもしれないメソッド {1} は、staticフィールド {2} に可変オブジェクトを格納することによって、内部の静的状態を暴露するかもしれません。
このコードはstatic フィールドに外部の可変オブジェクトを格納しています。 可変オブジェクトのチェックされていない変更がセキュリティや他の重要なプロパティを危うくするでしょう。 何か違うことをする必要があります。オブジェクトのコピーを保存することは、多くの状況でより良いアプローチです。

]]>
スレッドで run メソッドを呼び出している {1} は、スレッドで明示的に run メソッドを呼び出しています (start メソッドを意味していましたか?)。
このメソッドは、スレッドで 明示的に run メソッドを呼び出しています。 一般的にクラスは新しいスレッドで自己の run メソッドを呼び出してもらうために Runnable インタフェースを実装します。 その場合は、Thread.start() を呼び出すのが正しいです。

]]>
スピンロックをしているメソッド フィールド {2.givenClass} を使用してスピンロックをしています。{1}
このメソッドは、フィールドを読み出すループで回り続けます。 コンパイラがフィールドの読み出しをループの外に出すかもしれません。コードを無限ループに変えます。 正しい同期化 (wait/notify を呼び出すように含む) を使うようにクラスを変更するべきです。

]]>
潜在的な非短絡論理の危険な使用 潜在的な非短絡論理の危険な使用。{1}
このコードは短絡論理 (&& や ||) ではなく非短絡論理 (& や |) を使用していると思われます。 さらに、左辺値によって右辺を評価したくない (例外のスローや演算が高くつく副作用があるため) と思っているのかもしれません。 非短絡論理は、左辺を知ることによって結果を推論できたとしても両側の式が評価されます。 これは効率が悪く、右辺の評価でエラーが発生するケースを左辺でガードしているなら、結果としてエラーになる可能性があります。

詳細については、the Java Language Specification を参照してください。

]]>
非短絡論理の疑わしい使用 非短絡論理の疑わしい使用。{1}
このコードは短絡論理 (&& や ||) ではなく非短絡論理 (& や |) を使用していると思われます。 非短絡論理は、左辺を知ることによって結果を推論できたとしても両側の式が評価されます。 これは効率が悪く、右辺の評価でエラーが発生するケースを左辺でガードしているなら、結果としてエラーになる可能性があります。

詳細については、the Java Language Specification を参照してください。

]]>
2つ以上のロックを保持して wait メソッドを呼び出している 2つ以上のロックを保持して wait メソッドを呼び出しています。{1}
2つ以上のロックを保持して、モニタで待機させるとデッドロックを引き起こすことがあります。 wait メソッドを呼び出すと、待機しているオブジェクトのロックを解除するだけで、その他のロックは解除しません。 これは必ずしもバグではありませんが厳密に調べる価値があります。

]]>
Notify with two locks held notify() or notifyAll*() with two locks held in {1}
The code calls notify() or notifyAll() while two locks are held. If this notification is intended to wake up a wait() that is holding the same locks, it may deadlock, since the wait will only give up one lock and the notify will be unable to get both locks, and thus the notify will not succeed.   If there is also a warning about a two lock wait, the probably of a bug is quite high.

]]>
wait メソッドの無条件呼び出し wait メソッドを無条件で呼び出しています。{1}
このメソッドには条件制御フローによってガードされない java.lang.Object.wait() の呼び出しがあります。 このコードは wait メソッドを呼び出す前に待機するつもりだった条件が既に満たされていないことを確かめるべきです。 どんな前の通知も無視されます。

]]>
コンストラクタで初期化されていないフィールドを読み出している 初期化されていないフィールド {2.name} を読み出しています。{1}
このコンストラクタは、まだ値が代入されていないフィールドを読み出しています。 多くの場合、プログラマがコンストラクタのパラメータの代わりに誤ってフィールドを使うときに起きます。

]]>
スーパークラスのコンストラクタから呼び出されるメソッドで初期化されていないフィールドを読み出している スーパークラスのコンストラクタから呼び出されるとき、{2.name} は {1} で初期化されません。
このメソッドは、スーパークラスのコンストラクタで呼びされています。この時点では、クラスのフィールドはまだ初期化されていません。

これはたくさんの具象クラスを作るためです。以下のクラスを検討してください。

abstract class A {
    int hashCode;
    abstract Object getValue();
    
    A() {
        hashCode = getValue().hashCode();
    }
}

class B extends A {
    Object value;

    B(Object v) {
        this.value = v;
    }

    Object getValue() {
        return value;
    }
}

B が構築されるとき、B のコンストラクタが value に値を設定する前に、A クラスのコンストラクタが呼び出されます。 したがって、A のコンストラクタが getValue を呼び出すとき、value の初期化されていない値が読み出されます。

]]>
同期化していない get メソッド、同期化している set メソッド {1} は同期化していません、{2} は同期化しています。
このクラスには類似した名前の get メソッドと set メソッドがあり、set メソッドは同期化していて、get メソッドは同期化していません。 get メソッドの呼び出し元がオブジェクトの一貫した状態を必ずしも見るというわけではないので、実行時に間違った振る舞いの原因になることがあります。 get メソッドは同期化するべきです。

]]>
初期化が循環している {0} と {1} の間で初期化が循環しています。
バグインスタンスによって参照される2つのクラスのスタティックイニシャライザで循環が検出されました。 さまざまな予想外の振る舞いはそのような循環に起因することがあります。

]]>
スーパークラスは初期化中にサブクラスを使用している {0} の初期化は、まだ初期化されていないクラス {2} にアクセスしています。
クラスは、初期化中にサブクラスを積極的に使用しています。サブクラスはこの時点ではまだ初期化されていません。
たとえば、以下のコードにおいて、foo は null です。

public class CircularClassInitialization {
    static class InnerClassSingleton extends CircularClassInitialization {
        static InnerClassSingleton singleton = new InnerClassSingleton();
    }
    
    static CircularClassInitialization foo = InnerClassSingleton.singleton;
}
]]>
Iterator.next() が NoSuchElementException をスローできない {1} は、NoSuchElementException をスローできません。
このクラスは、java.util.Iterator を実装しています。 しかしながら、next メソッドは java.util.NoSuchElementException をスローできません。 next メソッドは、それ以上要素を返すことができないときは NoSuchElementException をスローするように変更するべきです。

]]>
正準化した文字列の同期化 正準化した文字列を同期化しています。{1}
このコードは正準化した文字列で同期化しています。

private static String LOCK = "LOCK";

synchronized(LOCK) {
    ...
}

文字列定数は正準化され、Java 仮想マシンによってロードされたすべてのクラス全体で共有されます。 したがって、これは他のコードがロックしているかもしれない何かをロックしている可能性があります。 これはブロッキングとデッドロックの振る舞いの診断を難しくして、とても奇妙な結果になる可能性があります。
詳細は、http://www.javalobby.org/java/forums/t96352.htmlhttp://jira.codehaus.org/browse/JETTY-352 を参照してください。

]]>
Boolean の同期化 Boolean を同期化しています。{1}
Boolean のようなボクシングされたプリミティブ型の定数で同期化しています。

private static Boolean inited = Boolean.FALSE;

synchronized(inited) { 
    if (!inited) {
        init();
        inited = Boolean.TRUE;
    }
}

一般には2つの Boolean オブジェクトだけが存在しています。 このコードは他の無関係なコードと同じオブジェクトで同期化している可能性があるので、無応答やデッドロックの原因になります。

]]>
ボクシングされたプリミティブ値の同期化 {2} を同期化しています。{1}
このコードは明らかに共有されていない Integer のようなボクシングされたプリミティブ型で同期化しています。

private static final Integer fileLock = new Integer(1);

synchronized(fileLock) { 
    .. do something ..
}

このコードは fileLock を以下のように宣言するとより良くなります。

private static final Object fileLock = new Object();

既存のコードとしては間違っていないかもしれないが、紛らわしいので将来リファクタリングするべきかもしれません。 たとえば、IntelliJ の "Remove Boxing" のようなリファクタリングは Java 仮想マシンを通して共有される正準化された Integer オブジェクトを使用するように置き換えてしまい、非常に紛らわしい振る舞いと潜在的デッドロックの原因になります。

]]>
デッドロックの原因になる可能性があるボクシングされたプリミティブ型の同期化 {2} の同期化はデッドロックの原因になる可能性があります。{1}
このコードはInteger のようなボクシングされたプリミティブ型の定数で同期化しています。

private static Integer count = 0;

synchronized(count) { 
    count++;
}

Integer オブジェクトはキャッシュして共有できます。 他の無関係なコードと同じオブジェクトで同期化している可能性があるので、無応答やデッドロックの原因になります。

CERT の CON08-J. Do not synchronize on objects that may be reused を参照してください。

]]>
空の synchronized ブロック 空のsynchronizedブロックです。{1}
このコードには空の synchronized ブロックがあります。

synchronized() {
}

空の synchronized ブロックは巧妙で正しく使用するのは困難です。 空の synchronized ブロックはわざとらしくて決して良い解決策ではありません。

]]>
一貫性のない同期化 {1} の同期化には一貫性がありません。{2}% の時間をロック
このクラスのフィールドは、同期化に関して一貫性のないアクセスをしているように見えます。 このバグレポートは、バグパターンディテクタが以下のように判断したことを示します。

  • クラスにはロックされたアクセスとアンロックされたアクセスが混在していて
  • 少なくとも1つのロックされたアクセスがクラス自身のメソッドの1つによって実行され、
  • 読み出しの2倍の重み付けをした書き込みで、非同期フィールドのアクセス (読み出しと書き込み) 数がすべてのアクセスのわずか1/3

このバグパターンに合致する典型的なバグは、スレッドセーフを意図したクラスでメソッドを同期化するのを忘れていることです。

不正確のいろいろなソースがこのディテクタにあることに注意してください。 たとえば、ディテクタはロックを保持されるすべての状況を静的に検出できるわけではありません。 また、ディテクタがロックされたアクセスとアンロックされたアクセスの区別が正確なときでも、問題のコードはまだ正しいかもしれません。

]]>
フィールドを同期化でガードしようとする無駄な試み {2.givenClass} を同期化でガードしようとする無駄な試みです。
このメソッドは、フィールドの同時更新に対して同期化でガードしようとしています。しかし、フィールドをガードするとフィールドではなく、フィールドが参照するオブジェクトのロックを獲得します。 これはあなたが必要とする相互排除ができないかもしれません。 他のスレッドは (他の目的のための) 参照されたオブジェクトのロックを獲得するかもしれません。
このパターンの例は以下のようになります。

private Long myNtfSeqNbrCounter = new Long(0);
private Long getNotificationSequenceNumber() {
     Long result = null;
     synchronized(myNtfSeqNbrCounter) {
         result = new Long(myNtfSeqNbrCounter.longValue() + 1);
         myNtfSeqNbrCounter = new Long(result.longValue());
     }
     return result;
}
]]>
更新されるフィールドで同期化しているメソッド {1} は、更新されるフィールド {2.givenClass} で同期化しています。
このメソッドは、可変フィールドから参照されたオブジェクトで同期化しています。 異なるスレッドが異なるオブジェクトで同期化しているかもしれないので、有用な意味を持っている可能性が低いです。

]]>
インタフェースから移動してパッケージプロテクテッドにすべきフィールド {1} は、インタフェースから移動してパッケージプロテクテッドにすべきです
インタフェースに定義された final static フィールドが配列や Hashtable などの可変オブジェクトを参照しています。 この可変オブジェクトは悪意のあるコードや偶然別のパッケージによって変更できます。 これを解決するためにフィールドはクラスへ移動する必要があり、脆弱性を回避するためにパッケージプロテクテッドにします。

]]>
final かつパッケージプロテクテッドにすべきフィールド {1} は、final かつパッケージプロテクテッドにすべきです。
この可変 static フィールドは悪意のあるコードや偶然別のパッケージによって変更できます。 フィールドは、脆弱性を回避するために final および/またはパッケージプロテクテッドにします。

]]>
final でないフィールドはリファクタリングするべき {1} は、final でないのでリファクタリングするべきです。
final でない public static フィールドは悪意のあるコードや偶然別のパッケージによって変更できます。 フィールドは、脆弱性を回避するために final にします。 しかしながら、スタティックイニシャライザには複数のフィールドへの書き込みがあるので、何らかのリファクタリングを必要とするでしょう。

]]>
final にすべきフィールド {1} は、final ではありませんが final にすべきです。
final でない public static フィールドは悪意のあるコードや偶然別のパッケージによって変更できます。 フィールドは、脆弱性を回避するために final にします。

]]>
パッケージプロテクテッドにすべきフィールド {1} は、パッケージプロテクテッドにすべきです。
この可変 static フィールドは悪意のあるコードや偶然別のパッケージによって変更できます。 フィールドは、脆弱性を回避するためにパッケージプロテクテッドにします。

]]>
可変 Hashtable のフィールド {1} は、可変 Hashtable です。
この final static フィールドは Hashtable を参照しているので、悪意のあるコードや偶然別のパッケージによってアクセスできます。 このコードはHashtable のコンテンツを自由に変更できます。

]]>
可変コレクションのフィールド {1} は可変コレクションです。
可変コレクションのインスタンスが final static フィールドに割り当てられています。 したがって、 悪意のあるコードや偶然別のパッケージによって変更できます。 脆弱性を避けるために Collections.unmodifiableSet/List/Map などでこのフィールドをラップすることを検討してください。

]]>
パッケージプロテクテッドにすべき可変コレクションのフィールド {1} は、パッケージプロテクテッドにすべき可変コレクションです。
可変コレクションのインスタンスが final static フィールドに割り当てられています。 したがって、悪意のあるコードや偶然別のパッケージによって変更できます。 フィールドは脆弱性を避けるためにパッケージプロテクテッドにできます。 代わりに Collections.unmodifiableSet/List/Map などでこのフィールドをラップしても脆弱性を避けることができます。

]]>
可変配列のフィールド {1} は、可変配列です。
この final static フィールドは配列を参照しているので、悪意のあるコードや偶然別のパッケージによってアクセスできます。 このコードは配列のコンテンツを自由に変更できます。

]]>
final でないフィールドは悪意のあるコードから保護できない {1} は、final でないので、悪意のあるコードから保護できません。
この可変 static フィールドは悪意のあるコードや偶然別のパッケージによって変更できます。 残念ながらこのような使い方は簡単に解決できません。

]]>
列挙型フィールドは public で可変である {1} フィールドは public で可変です。
可変 public フィールドが public 列挙型の中に定義されています。 したがって、フィールドは悪意のあるコードや偶然別のパッケージによって変更できます。 可変列挙型フィールドが遅延初期化で使用されるかもしれないとしても外界へ暴露するバッドプラクティスです。 このメソッドを final およびパッケージプライベートとして宣言することを考えてください。

]]>
public 列挙型メソッドが無条件にフィールドを設定する {1} は無条件にフィールド {2.name} を設定しています。
無条件に列挙型フィールドを設定している public 列挙型で public メソッドを宣言しています。 したがって、フィールドは悪意のあるコードや偶然別のパッケージによって変更できます。 可変列挙型フィールドが遅延初期化で使用されるかもしれないとしても外界へ暴露するバッドプラクティスです。 このメソッドを除去するかパッケージプライベートとして宣言することを考えてください。

]]>
潜在的な継承されたメソッドなのか外部のメソッドなのかあいまいなメソッドの呼び出し 潜在的な継承されたメソッドなのか外部のメソッドなのかあいまいなメソッド {2} を呼び出しています。{1}
内部クラスは、継承されたメソッドか外部クラスで定義されたメソッドなのかどちらとも解釈できるメソッドを呼び出しています。 たとえば、foo(17) を呼び出します。それはスーパークラスと外部のメソッドの両方で定義されています。 Java のセマンティックスでは、継承したメソッドを呼び出しますが、これはあなたが意図したことではないかもしれません。

本当に継承されたメソッドを呼び出すつもりなら super を付けて (例:super.foo(17)) 呼び出してください。 そうすれば、外部クラスのメソッドではなく継承されたメソッドを呼び出したいことがこのコードを読む人と FindBugs に明確になります。

this.foo(17) を呼び出す場合は、継承されたメソッドが呼び出されます。 しかしながら、FindBugs はクラスファイルを見るだけなので、this.foo(17)foo(17) の呼び出しの違いを見分けることができません。 潜在的なあいまいな呼び出しについて文句を言うでしょう。

]]>
クラス名はスーパークラスの単純名を遮るべきではない クラス名 {0} は、スーパークラス {1} の単純名を遮ります。
このクラスは、スーパークラスが異なるパッケージであるということを除いて、スーパークラスと同一の単純名をです (たとえば、alpha.Foobeta.Foo を拡張します)。 これは非常に紛らわしく、参照関係を解決するために import 文を見なければならなかったり、スーパークラスのメソッドをオーバーライドしないで誤ってメソッドを定義する状況を作り出します。

]]>
クラス名は実装されたインタフェースの単純名を遮るべきではない クラス名 {0} は、実装されたインタフェース {1} の単純名を遮ります。
このクラスまたはインタフェースは、インタフェースが異なるパッケージであるということを除いて実装された/拡張されたインタフェースと同一の単純名です (たとえば、alpha.Foobeta.Foo を継承しているような状況です)。 これは非常に紛らわしく、参照関係を解決するために import 文を見なければならなかったり、スーパークラスのメソッドをオーバーライドしないで誤ってメソッドを定義する状況を作り出します。

]]>
クラス名は大文字から始めるべき クラス名 {0} は、大文字から始まっていません。
クラス名は、最初の文字とそれに続く各単語の最初の文字を大文字にした名詞にすべきです。 クラス名は単純でわかりやすいようにしてください。 頭文字や略語 (URLやHTMLなどのように略語がロング形式よりもはるかに広く使われている場合を除く) の使用は避けてください。

]]>
メソッド名は小文字から始めるべき メソッド名 {1} は、小文字から始まっていません。
メソッド名は、最初の文字は小文字にし、それに続く各単語の最初の文字を大文字にした動詞にすべきです。

]]>
フィールド名は小文字から始めるべき フィールド名 {1} は、小文字から始まっていません。
final でないフィールドの名前は、最初の文字は小文字にし、それに続く各単語の最初の文字を大文字にすべきです。

]]>
非常に紛らわしい名前のメソッド {1} と {3} は、非常に紛らわしいです。
参照されたメソッドは、大文字の使い方だけによって異なる名前があります。 大文字の使い方が同一ならメソッドの1つが他のメソッドをオーバーライドするので、非常に紛らわしいです。

]]>
非常に紛らわしい名前のメソッド (多分意図的) {1} と {3} のメソッドは、非常に紛らわしいです (多分意図的)。
参照されたメソッドは、大文字の使い方だけによって異なる名前があります。 大文字の使い方が同一ならメソッドの1つが他のメソッドをオーバーライドするので、非常に紛らわしいです。 他のメソッドの存在から、これらのメソッドの両方の存在が意図的で、確実に混乱させていると思われます。 APIの凍結によって両方とも持たざるを得ない場合を除き、それらのうちの1つを除去しようと努力するべきです。

]]>
パラメータの間違ったパッケージのためにスーパークラスのメソッドをオーバーライドしていないメソッド パラメータの型 {4} がスーパークラスのパラメータの型 {5} と合致していないので、{1} はスーパークラスのメソッドをオーバーライドしていません。
パラメータの型がスーパークラスで対応するパラメータの型と正確に合致していないので、サブクラスのメソッドはスーパークラスの類似したメソッドをオーバーライドしていません。
たとえば以下のようなコードです。

import alpha.Foo;

public class A {
    public int f(Foo x) { return 17; }
}
----
import beta.Foo;

public class B extends A {
    public int f(Foo x) { return 42; }
}

クラス B で定義された f(Foo) メソッドは、クラス Af(Foo) メソッドをオーバーライドしていません。 これは引数の型 Foo が違うパッケージだからです。

]]>
パラメータの間違ったパッケージのためにスーパークラスのメソッドをオーバーライドしていないメソッド パラメータの型 {4} がスーパークラスのパラメータの型 {5} と合致しないので、{1} はスーパークラスのメソッドをオーバーライドしていません。
パラメータの型が正確にスーパークラスで対応するパラメータの型と合致していないので、サブクラスのメソッドはスーパークラスの類似したメソッドをオーバーライドしていません。
たとえば以下のようなコードです。

import alpha.Foo;

public class A {
    public int f(Foo x) { return 17; }
}
----
import beta.Foo;

public class B extends A {
    public int f(Foo x) { return 42; }
    public int f(alpha.Foo x) { return 27; }
}

クラス B で定義された f(Foo) メソッドは、クラス Af(Foo) メソッドをオーバーライドしません。 これは引数の型 Foo が違うパッケージだからです。

この場合、サブクラスがスーパークラスのメソッドと同一のシグネチャでメソッドを定義しているので、おそらく理解できます。 しかしながら、そのようなメソッドは非常に紛らわしいです。 類似しているが同一ではないシグネチャのメソッドを除去するか、非推奨にすることを強く検討するべきです。

]]>
紛らわしい名前のメソッド {1} と {3} は、紛らわしいです。
参照されたメソッドは、大文字の使い方だけによって異なる名前があります。

]]>
明らかなメソッドとコンストラクタの混乱 {1} は、おそらくコンストラクタにすることを意図していました。
この正規のメソッドは定義しているクラスと同じ名前です。 これはコンストラクタを意図していた可能性が高いです。もしそうなら void 戻り値の宣言を除去してください。 偶然メソッドを定義したことが間違いだとわかり、適切なコンストラクタを定義したが、後方互換性のためにこのメソッドを除去できないならメソッドを非推奨にしてください。

]]>
クラスは hashcode() を定義しています。hashCode() にすべきですか? クラス {0} は、hashcode() を定義しています。hashCode() にすべきですか?
このクラスは、hashcode() という名前のメソッドを定義しています。 このメソッドは、java.lang.ObjecthashCode メソッドを (おそらく意図的に) オーバーライドしていません。

]]>
クラスは tostring() を定義しています。toString() にすべきですか? クラス {0} は、tostring() を定義しています。toString() にすべきですか?
このクラスは、tostring() という名前のメソッドを定義しています。 このメソッドは、java.lang.ObjecttoString メソッドを (おそらく意図的に) オーバーライドしていません。

]]>
クラスは equal(Object) を定義しています。equals(Object) にすべきですか? クラス {0} は equal(Object) を定義しています。equals(Object) にすべきですか?
このクラスは、equal(Object) という名前のメソッドを定義しています。 このメソッドは、java.lang.Objectequals(Object) を (おそらく意図的に) オーバーライドしていません。

]]>
例外クラスのように命名されているが、クラスは Exception から派生されていない 例外クラスのように命名されていますが、クラス {0} は、Exception から派生されていません。
このクラスは、例外クラスから派生されていないのにクラス名が「Exception」で終わっています。 これはこのクラスのユーザに紛らわしいです。

]]>
InputStream.read() の戻り値を無視しているメソッド {1} は、 {2} の戻り値を無視しています。
このメソッドは、複数バイトを返す可能性がある java.io.InputStream.read() (またはそのバリエーション) の戻り値を無視しています。 戻り値がチェックされないと呼び出し元は要求したバイト数よりも少ないバイト数を読み出した場合、正しく処理できません。 これは潜在的なバグで、多くのプログラムでは、入力ストリームからの読み出しは、通常要求した完全なデータ量を読み出しますが、散発的に失敗することがあります。

]]>
InputStream.skip() の戻り値を無視しているメソッド {1} は、 {2} の戻り値を無視しています。
このメソッドは、複数バイトをスキップする可能性がある java.io.InputStream.skip() の戻り値を無視しています。 戻り値がチェックされないと呼び出し元は要求したバイト数よりも少ないバイト数しかスキップしなかった場合、正しく処理できません。 これは潜在的なバグで、多くのプログラムでは、入力ストリームからのスキップは、通常要求した完全なデータ量をスキップをしますが、散発的に失敗することがあります。 しかしながら、バッファードストリーム での skip メソッドはバッファのデータをスキップするので要求されたバイト数のスキップは常に失敗します。

]]>
readResolve メソッドが static メソッドとして宣言されている {1} は、static メソッドではなく インスタンスメソッドとして宣言するべきです。
readResolve メソッドが直列化機構で認識されるためには static メソッドとして宣言してはいけません。

]]>
サブクラスで継承できない private な readResolve メソッド サブクラスで継承できない {0} の private な readResolve メソッドです。
このクラスは、private な readResolve メソッドを定義しています。 そのため、このメソッドはサブクラスで継承できません。 これが意図したことなら間違っていないかもしれませんが確認するためにレビューするべきです。

]]>
readResolve メソッドの戻り値の型が Object で宣言されていない メソッド {1} の戻り値の型は {1.returnType} ではなく Object で宣言されなければなりません。
readResolve メソッドが直列化機構で認識されるためには戻り値の型が Object で宣言されなければなりません。

]]>
Serializable でないクラスの transient フィールド {1.givenClass} は、transient ですが、{0} は Serializable ではありません。
フィールドは、transient と宣言していますが、クラスは直列化可能ではないので、まったく効果がありません。 クラスが transient だったときの名残かもしれません、または直列化機構を誤解しているのかもしれません。

]]>
直列化復元によって設定されない transient フィールド フィールド {1} は、transient なので直列化復元によって設定されません。
このクラスには複数の場所で更新されるフィールドがあります。したがって、このクラスの状態の一部だと思われます。 しかしながら、フィールドは transient と宣言しているので、 readObject/readResolve で値が設定されません。 クラスの直列化復元されたインスタンスにはデフォルト値が設定されます。

]]>
直列化機構のために private にしなければならないメソッド メソッド {1.givenClass} は、{0} の直列化/直列化復元で呼び出されるために private にしなければなりません。
このクラスは、Serializable インタフェースを実装して、カスタム直列化/直列化復元のためのメソッドを定義しています。 しかし、そのメソッドが private として宣言されていないので、直列化/直列化復元 API によって無視されます。

]]>
Externalizable なクラスが引数なしコンストラクタを定義していない {0} は、Externalizable を実装していますが、引数なしコンストラクタを定義していません。
このクラスは、Externalizable インタフェースを実装していますが、引数なしコンストラクタを定義していません。 Externalizable オブジェクトが直列化復元されるときは、最初に引数なしコンストラクタを呼び出すことによって構築される必要があります。 このクラスには引数なしコンストラクタがないので、直列化と直列化復元は実行時に失敗します。

]]>
Serializable なクラスのスーパークラスで、引数なしコンストラクタを定義していない {0} は、Serializable を実装していますが、そのスーパークラスはアクセス可能な引数なしコンストラクタを定義していません。
このクラスは Serializable インタフェースを実装していますが、そのスーパークラスは実装していません。 そのようなオブジェクトが直列化復元されるとき、スーパークラスのフィールドはスーパークラスの引数なしコンストラクタを呼び出すことによって初期化される必要があります。 スーパークラスには引数なしコンストラクタがないので、直列化と直列化復元は実行時に失敗します。

]]>
Serializable なクラスが serialVersionUID を定義していない {0} は、Serializable を実装していますが、serialVersionUID は定義していません。
このクラスは Serializable インタフェースを実装していますが、serialVersionUID フィールドを定義していません。 .class オブジェクトへの参照を追加するのと同じくらい簡単な変更でクラスに合成フィールドを追加します。 それは、残念ながら暗黙の serialVersionUID を変えます (たとえば、String.class への参照を追加すると、class$java$lang$String という static フィールドを生成します)。 また、バイトコードコンパイラへの異なるソースコードは、クラスオブジェクトまたは内部クラスを参照するために生成される合成変数のために異なる命名規則を使用するかもしれません。 バージョンを横断する Serializable の相互運用性を保証するために明示的に serialVersionUID を追加することを検討してください。

]]>
Comparator は Serializable を実装していない {0} は、Comparator を実装していますが、Serializable を実装していません。
このクラスは Comparator インタフェースを実装しています。 Serializable インタフェースも実装するべきかどうか検討するべきです。 コンパレータが TreeMap のような順序付きコレクションを構築するために使われるなら、コンパレータが直列化可能な場合だけ、TreeMap は直列化可能です。 大部分のコンパレータがほとんど状態を持たないとしても直列化可能にすることは簡単で良い防衛的なプログラミングです。

]]>
1つの case が次の case へと通り抜ける switch 文を見つけた 1つの case が次の case へと通り抜ける switch 文を見つけました。{1}
このメソッドには1つの case が次の case へと通り抜ける switch 文があります。 通常は、break か return でこの case を終わらせる必要があります。

]]>
default がない switch 文を見つけた default がない switch 文を見つけました。{1}
このメソッドにはdefault がない switch 文があります。 通常は、default を用意する必要があります。

解析は生成されたバイトコードを見るだけなので、default が switch 文の終わりにあって、他のケースに break 文が含まれていないなら誤検出のトリガーとなります。

]]>
switch 文のフォールスルーのために格納が無効になっている 前の case からの値 {2.givenClass} が switch 文のフォールスルーのためにここで上書きされています。
前の case で格納された値が switch 文のフォールスルーのためにここで上書きされています。 前の case の終わりに break または return を入れるのを忘れた可能性があります。

]]>
スローする switch 文のフォールスルーのために格納が無効になっている 前の case からの値 {2.givenClass} がスローする switch 文のフォールスルーのためにここで失われています。
前の case で格納された値が例外がスローされる場所で、switch 文のフォールスルーのためにここで失われています。 前の case の終わりに break または return を入れるのを忘れた可能性があります。

]]>
writeObject メソッドは同期化しているがその他のメソッドは同期化していないクラス {0} の writeObject メソッドは同期化していますが、その他のメソッドは同期化していません。
このクラスには同期化している writeObject メソッドがあります。 しかしながら、クラスのその他のメソッドは同期化していません。

]]>
readObject メソッドを同期化しているクラス {0} の readObject メソッドを同期化しています。
この直列化可能クラスは同期化する readObject メソッド を定義していますが、 直列化復元によって作成されるオブジェクトは1つのスレッドによってだけ到達可能です。 したがって、readObject メソッドは同期化する必要がありません。 readObject メソッドそのものが別のスレッドに見えるようになるオブジェクトの原因になっているなら非常に疑わしいコーディングスタイルの例です。

]]>
serialVersionUID が static ではない {1} は、static ではありません。
このクラスは、static でない serialVersionUID フィールドを定義しています。 直列化を目的としてバージョン UID を指定することを意図しているならフィールドは static とすべきです。

]]>
serialVersionUID が final ではない {1} は、 final ではありません。
このクラスは、final でない serialVersionUID フィールドを定義しています。 直列化を目的としてバージョン UID を指定することを意図しているならフィールドは final とすべきです。

]]>
serialVersionUID が long ではない {1} は、long ではありません。
このクラスは、long でない serialVersionUID フィールドを定義しています。 直列化を目的としてバージョン UID を指定することを意図しているならフィールドは long とすべきです。

]]>
直列化可能クラスの非 transient で非直列化可能なインスタンスフィールド クラス {0} は、非 transient で非直列化可能なインスタンスフィールド {1.name} を定義しています。
この直列化可能クラスは、transient、Serializable、java.lang.Object でもない非プリミティブ型のインスタンスフィールドを定義して、 Externalizable インタフェースまたは readObject メソッドと writeObject メソッドを実装するように見えません。 また、Externalizable インタフェースも実装していなくて、readObject メソッドも writeObject メソッドも定義していません。 非直列化可能オブジェクトがこのフィールドに格納されるならクラスのオブジェクトは正しく直列化復元されません。

]]>
非直列化可能クラスに直列化可能な内部クラスがある {0} は、直列化可能ですが、非直列化可能クラスの内部クラスです。
この直列化可能クラスは、非直列化可能クラスの内部クラスです。 内部クラスを直列化しようとすると関連する外部クラスのインスタンスを結びつけようとするので、実行時エラーの原因になります。

できれば、内部クラスを static にして問題を解決するべきです。 外部クラスを直列化可能にすることで動作するかもしれないが、内部クラスのインスタンスを直列化することは外部クラスも常に直列化することを意味します。 本当に望むことですか。

]]>
直列化可能な内部クラス {0} は直列化可能な内部クラスです。
この直列化可能なクラスは内部クラスです。内部クラスを直列化しようとすると関連した外部クラスのインスタンスも直列化します。 外部クラスのインスタンスは直列化可能なので失敗しません。しかし、意図していたよりももっと多くのデータを直列化するかもしれません。 できれば、内部クラスを static にして問題を解決するべきです。

]]>
非直列化可能な値を直列化可能クラスのインスタンスフィールドに格納している 非 transient フィールド {1.givenClass} に {2} を格納しています。
非直列化可能な値を直列化可能クラスの 非 transient フィールドに格納しています。

]]>
Thread.start() を呼び出しているコンストラクタ {1} は、{2} を呼び出しています。
コンストラクタがスレッドを開始しています。クラスが拡張され、サブクラスが作られるなら間違っていそうです。 なぜなら、サブクラスのコンストラクタでスレッドが開始される前にスーパークラスのスレッドが開始されてしまうためです。

]]>
読み出されないフィールド 読み出されないフィールド: {1}; このフィールドは static にすべきですか?
このクラスにはコンパイル時に静的な値に初期化されるインスタンス final フィールドがあります。 static フィールドにすることを検討してください。

]]>
未使用のフィールド 未使用のフィールド: {1}
このフィールドは決して使われません。クラスから除去することを検討してください。

]]>
読み出されないフィールド 読み出されないフィールド: {1}
このフィールドは決して読み出されません。クラスから除去することを検討してください。

]]>
未使用の public または protected フィールド 未使用の public または protected フィールド: {1}
このフィールドは決して使用されません。 フィールドは、public か protected なので、多分、それは解析の一部として見えないクラスで使用されることを意図しています。 そうでなければ、クラスから除去することを検討してください。

]]>
読み出されない public または protected フィールド 読み出されない public または protected フィールド: {1}
このフィールドは決して読み出されません。 フィールドは、public か protected なので、多分、それは解析の一部として見えないクラスで使用されることを意図しています。 そうでなければ、クラスから除去することを検討してください。

]]>
複雑か巧妙か間違ったインクリメントの for ループ 複雑か巧妙か間違ったインクリメントの for ループです。{1}
本当にこの for ループが正しい変数をインクリメントしていますか? 別の変数が for ループによって初期化されてチェックされるように見えます。

]]>
null に設定されるだけのフィールド null に設定されるだけのフィールド:{1}
このフィールドに定数値 null を書き込みます。したがって、フィールドの読み出しは null を返します。 誤りをチェックしてください。役に立たないなら除去してください。

]]>
書き込まてれいない public または protected フィールド 書き込まれていない public または protected フィールド: {1}
この public または protected フィールドは書き込まれていません。このフィールドからの読み出しはデフォルト値を返します。 誤りをチェックしてください (フィールドは初期化するべきでしたか?)。役に立たないなら除去してください。

]]>
書き込まれていないフィールド 書き込まれていないフィールド: {1}
このフィールドは決して書き込まれません。このフィールドからの読み出しはデフォルト値を返します。 誤りをチェックしてください (フィールドは初期化するべきでしたか?)。役に立たないなら除去してください。

]]>
インスタンスメソッドから static フィールドへの書き込み インスタンスメソッド {1} から static フィールド {2} に書き込みをしています。
このインスタンスメソッドは、static フィールドに書き込みをしています。 複数のインスタンスが操作されているなら、正しくさせるのは難しいです。一般的にバッドプラクティスです。

]]>
null とわかっている値のロード null とわかっている値をロードしています。{1}
ここで参照されている変数は、以前に null なのかチェックしているため null であることがわかっています。 これは有効ですが、間違いかもしれません (多分異なる変数を参照することを意図してました、または以前の null チェックで null でないのか確かめるべきでした)。

]]>
readLine メソッドの結果が null なのか確かめないで値を利用している readLine メソッドの結果が null なのか確かめないで値を利用しています。{1}
readLine メソッドの結果が null なのか確かめないで値を利用しています。 readLine メソッドは、それ以上読み出すテキスト行がなければ null を返すので、NullPointerException が発生します。

]]>
readLine メソッドの結果をすぐに利用している readLine メソッドの結果をすぐに利用しています。{1}
readLine メソッドの結果をすぐに利用しています。 readLine メソッドは、それ以上読み出すテキスト行がなければ null を返すので、NullPointerException が発生します。

]]>
書き込まれていないフィールドの読み出し 書き込まれていないフィールド {2.name} を読み出しています。{1}
プログラムは、決して null でない値を書き込むとは思われないフィールドの値を利用しています。 この値を利用すると NullPointerException が発生します。

]]>
書き込まれていない public または protected フィールドの読み出し 書き込まれていない public または protected フィールド {2.name} を読み出しています。{1}
プログラムは、決して null 値でない値を書き込むと思われない public または protected フィールドの null 値を利用しています。 フィールドが解析によって見られない機構を通して初期化されないかぎり、この値を利用すると NullPointerException が発生します。

]]>
非 static 内部クラスとスレッドローカルのデッドロック {0} は、{1} とのデッドロックを回避するために static にする必要があります。
このクラスは内部クラスですが、おそらく static 内部クラスにすべきです。 実際には内部クラスと外部クラスのスレッドローカルとの間にデッドロックの深刻な危険性があります。 内部クラスが static でないので、外部クラスへの参照を保持します。 スレッドローカルに内部クラスのインスタンスの参照があるなら、内部と外部のインスタンスの両方が到達可能になり、ガベージされません。

]]>
static 内部クラスにすべき {0} は、static 内部クラスにすべきです。
このクラスは内部クラスなのにそれを作成したオブジェクトへの埋め込まれた参照を使用していません。 この参照はより大きなクラスのインスタンスを作成して、必要以上に作成オブジェクトへの参照を存続しておくことがあります。 できれば、クラスは static にすべきです。

]]>
コンストラクタで初期化されていないフィールドを null チェックなしで null 値を利用している {1.givenClass} は、コンストラクタで初期化されません。{2} で null 値を利用しています。
このフィールドは、どんなコンストラクタの中でも決して初期化されません。したがって、オブジェクトが構築された後、null である可能性があります。 どこかほかで、値がロードされて、null チェックなしで null 値が利用されます。 フィールドが初期化される前に利用されると NullPointerException が発生するので、誤りか疑わしい設計かもしれません。

]]>
名前付き static 内部クラスにリファクタリングできるかもしれない クラス {0} は、名前付き static 内部クラスにリファクタリングできるかもしれません。
このクラスは内部クラスなのにそれを作成したオブジェクトへの埋め込まれた参照を使用していません。 この参照はより大きなクラスのインスタンスを作成して、必要以上に作成オブジェクトへの参照を存続しておくことがあります。 できれば、クラスは static 内部クラスにすべきです。 無名内部クラスは static にできないので、名前付き内部クラスにリファクタリングする必要があります。

]]>
static 内部クラスにリファクタリングできるかもしれない クラス {0} は、static 内部クラスにリファクタリングできるかもしれません。
このクラスは内部クラスなのにそれを作成したオブジェクトへの埋め込まれた参照を使用していません。 この参照はより大きなクラスのインスタンスを作成して、必要以上に長く作成オブジェクトへの参照を存続しておくかもしれません。 できれば、クラスは static 内部クラスにすべきです。 外部オブジェクトへの参照が内部クラスのインスタンスを構築する間必要なので内部クラスのコンストラクタに外部インスタンスへの参照を渡すようにリファクタリングする必要があります。

]]>
wait メソッドがループの中にない wait メソッドがループの中にありません。{1}
このメソッドは、ループの中にない java.lang.Object.wait() を呼び出しています。 モニタが複数の条件のために使われるなら、呼び出し元が待機するつもりだった条件は実際には発生しないかもしれません。

]]>
Condition.await() がループの中にない Condition.await() がループの中にありません。{1}
このメソッドは、ループの中にない java.util.concurrent.await() (またはそのバリエーション) を呼び出しています。 オブジェクトが複数の条件のために使われるなら、呼び出し元が待機するつもりだった条件は実際には発生しないかもしれません。

]]>
notifyAll メソッドではなく notify メソッドを使用している notifyAll メソッドではなく notify メソッドを使用しています。{1}
このメソッドは、notifyAll メソッドではなく notify メソッドを呼び出しています。 モニタが複数の条件のために多くの場合使われます。 notify メソッドの呼び出しは1つのスレッドを起こすだけで起こされたスレッドは呼び出し元が満たした待機条件の1つではないかもしれないことを意味しています。

]]>
役に立たない空ではない void メソッド メソッド {1} は、役に立たないようです。
我々の解析は、この空ではない void メソッドが実際に有用な仕事を行わないことを示しています。 確認してください。おそらくそのコードが間違っているか、またはボディを完全に除去できます。

我々はできる限り誤検出を減らそうと努力しているが、いくつかのケースでは警告は間違っているかもしれません。 よくある誤検出例です。

- メソッドは、副作用を持つかもしれないクラスのロードをトリガすることを意図している

- メソッドは、暗黙のわかりにくい例外をスローするように意図されている

]]>
条件は効果がない 役に立たない条件: この時点 {2} で知られていました。
この条件は前に絞られた関係している変数の値と同じ結果を常に作り出します。 おそらく何かほかのことを意味していたのか、あるいは条件を除去できます。

]]>
条件は変数型のために効果がない 役に立たない条件: 変数型が {3} なので、常に {2} です。
この条件は関係している変数の型範囲のために同じ結果を常に作り出します。 おそらく何かほかのことを意味していたのか、あるいは条件を除去できます。

]]>
役に立たないオブジェクトを作成した 役に立たないオブジェクトをメソッド {1} の変数 {2} で格納しました。
我々の解析でオブジェクトが役に立たないことを示しています。 作成され、変更されていますが、値はメソッドの外に出ないし、副作用をもたらしません。 間違いかオブジェクトが使われることを意図していたかのどちらか、あるいは除去できます。

この解析はめったに誤検出することはありません。よくある誤検出のケースです。

- 暗黙のうちに曖昧な例外をスローした

- コードを一般化してスタブとして使用された

- 弱/ソフト参照オブジェクトへの強い参照を持っていた

]]>
役に立たないオブジェクトをスタックで作成した 役に立たないオブジェクトをメソッド {1} で作成しました。
このオブジェクトは副作用を持たない修正を行うために作成されています。 おそらく何かほかのことを意味していたのか、あるいはオブジェクトを除去できます。

]]>
配列インデックスは範囲外 配列インデックスは範囲外です: {3}
配列演算が行なわれますが、配列インデックスが範囲外なので実行時に ArrayIndexOutOfBoundsException が発生するでしょう。

]]>
配列オフセットは範囲外 配列オフセットは範囲外です: {3}
メソッドは、配列パラメータとオフセットパラメータで呼び出されますが、オフセットは範囲外です。 実行時に IndexOutOfBoundsException が発生するでしょう。

]]>
配列の長さは範囲外 配列の長さは範囲外です: {3}
メソッドは、配列パラメータと長さパラメータで呼び出されますが、長さは範囲外です。 実行時に IndexOutOfBoundsException が発生するでしょう。

]]>
文字列インデックスは範囲外 文字列インデックスは {5} を呼び出すときに範囲外です: {3}
文字列メソッドが呼び出されます。指定された文字列インデックスは範囲外です。 実行時に StringIndexOutOfBoundsException が発生するでしょう。

]]>
String.indexOf の結果が正かどうか確かめている String.indexOf の結果が正かどうか確かめています。{1}
このメソッドは String.indexOf を呼び出して結果が正かどうか確かめています。 結果が負かどうか確かめるほうがずっと典型的です。チェックされる部分文字列が先頭以外の場所で出現するときだけ正になります。

]]>
readLine メソッドの結果を null でないのか確かめた後で捨てている {1} は、readLine メソッドの結果を null でないのか確かめた後で捨てています。
readLine メソッドの戻り値を null でないのか確かめた後で捨てています。 ほとんどすべての状況で、結果が null でないなら戻り値を使用したいでしょう。 再び readLine メソッドを呼び出すと異なる行が得られます。

]]>
副作用がないメソッドの戻り値は無視される 副作用がない {2.givenClass} の戻り値は無視されます。
このコードはメソッドを呼び出して戻り値を無視しています。 しかしながら、解析はメソッド (もしあればサブクラスの実装も含む) が戻り値以外の効果をもたらさないことを示しています。 この呼び出しは除去できます。

我々は、できる限り誤検出を減らそうとしていますが、いくつかのケースではこの警告が間違っているかもしれません。 よくある誤検出です。

- メソッドは、オーバライドされ解析対象外の他のプロジェクトで副作用がもたらされるように設計されている

- メソッドは、副作用をもたらすかもしれないクラスローダをトリガーするように呼び出されている

- メソッドは、例外を取得するために呼び出されている

我々の仮定が正しくないと感じるなら、FindBugs にこのメソッドの戻り値が無視されることを許容するように指示する @CheckReturnValue アノテーションを使用することができます。

]]>
メソッドは戻り値を無視しています。これは間違いではないですか? {2.givenClass} の戻り値を無視しています、これは間違いではないですか? {1}
このコードはメソッドを呼び出して、戻り値を無視しています。 戻り値は、メソッドが呼び出される型と同じ型です。そして、我々の解析から戻り値が重要であるかもしれないように見えます (たとえば、String.toLowerCase() の戻り値を無視するような)。

我々は、戻り値を無視することがメソッド本体の単純な解析から悪い考えかもしれないと推測しています。 このメソッドの戻り値を無視することが重要であるか許容できるかどうかに関して、FindBugs に指示する @CheckReturnValue アノテーションが使えます。

戻り値を無視することが間違いではないか決めるために厳密に調査してください。

]]>
戻り値を無視しているメソッド {2.givenClass} の戻り値を無視しています。{1}
このメソッドの戻り値はチェックするべきです。 この警告の共通の原因は、オブジェクトが更新されると思って不変オブジェクトのメソッドを呼び出すことです。
たとえば以下のようなコードです。

String dateString = getHeaderField(name);
dateString.trim();

プログラマは、trim メソッドが dateString によって参照される String オブジェクトが更新されると思っています。 しかし、String オブジェクトは不変で、trim メソッドが新しい String オブジェクトを返すのに無視しています。 このコードは以下のように修正するべきです。

String dateString = getHeaderField(name);
dateString = dateString.trim();
]]>
例外的戻り値を無視しているメソッド {2} の例外的戻り値を無視しています。{1}
このメソッドはチェックされていない値を返しています。 戻り値は異常か予想外の実行結果を示す可能性があるのでチェックするべきです。 たとえば、File.delete() はファイルをうまく削除できなかったなら、例外をスローするのではなく false を返します。 結果をチェックしないなら例外的戻り値を返すメソッドの呼び出しで予想外の振る舞いの合図に気づきません。

]]>
compareTo によって返された特定の値のコードチェック {2.givenClass} の戻り値が {3} と等しいか確かめてください。
このコードはcompareTo または compare メソッドを呼び出して、戻り値が特定の値(たとえば1または-1) なのか確かめています。 これらのメソッドを呼び出すときは特定のゼロ以外の値ではなく、結果の符号だけをチェックするべきです。 多数または大部分の compareTo と比較メソッドは-1、0または1を返しますが、いくつかは他の値を返します。

]]>
作成した例外をスローするのではなく捨てている {2.givenClass} をスローしていません。{1}
このコードは例外 (またはエラー) オブジェクトを作成していますが、何もしていません。
たとえば以下のようなコードです。

if (x < 0) {
    new IllegalArgumentException("x must be nonnegative");
}

おそらくプログラマの意図は、作成した例外をスローすることでした。

if (x < 0) {
    throw new IllegalArgumentException("x must be nonnegative");
}
]]>
null 値を利用している {2.givenClass} の null 値を利用しています。{1}
ここで null 値を利用しようとしています。 コードが実行されると NullPointerException が発生します。

]]>
常に null 値のオブジェクトで close メソッドを呼び出している 常に null なので {2.givenClass} をクローズできません。{1}
close メソッドは、常に null 値のオブジェクトで呼び出されています。 この文が実行されるなら NullPointerException が発生します。 ここでクローズするべき何かを決してクローズしないという大きな危険性があります。

]]>
@Nonnull でアノテートされたフィールドに null を格納している @Nonnull でアノテートされたフィールド {2.givenClass} に null を格納しています。{1}
@Nonnull としてアノテートされたフィールドに null かもしれない値を格納しています。

]]>
null 値を例外経路で利用している {2.givenClass} の null 値を例外経路で利用しています。{1}
例外経路上のここで null 値を利用しています。コードが実行されると NullPointerException が発生します。 現在の FindBugs は実行不可能な例外経路を刈り取れていないので、誤検出かもしれないことに注意してください。

switch 文の default が多くの場合実行不可能なので FindBugs が例外経路である default を検討することに注意して下さい。

]]>
パラメータは 非 null でなければならないが null 可能としてアノテートされている {2} は、非 null でなければならないが null 可能としてアノテートされています。
このパラメータは、常に 非 null にすることを要求する方法で使われていますが、パラメータには明示的に null 可能としてアノテートされています。 パラメータかアノテーションのどちらかの使い方が間違っています。

]]>
null 値を利用している可能性がある {2.givenClass} の null 値を利用している可能性があります。{1}
そこで分岐または文が実行されるなら null 値が利用されて NullPointerException が発生します。 もちろん、問題は分岐または文が実行不可能で、NullPointerException が決して発生する可能性がないということかもしれません。 それを決めるのは FindBugs の能力を超えています。

]]>
null 値を実行不可能かもしれない分岐で利用している可能性がある {2.givenClass} の null 値を実行不可能かもしれない分岐で利用している可能性があります。{1}
分岐または文が実行されるなら、null 値が利用されて NullPointerException が発生します。 もちろん、問題は分岐または文が実行不可能で、NullPointerException が決して発生する可能性がないということかもしれません。 それを決めるのは FindBugs の能力を超えています。 この値が既に null であることを検査したという事実からこれは明確な可能性です。

]]>
null 値を例外経路で利用している可能性がある {2.givenClass} の null 値を例外経路で利用している可能性があります。{1}
例外経路上のここで null 値が利用されています。コードが実行されると NullPointerException を引き起こすことがあります。 現在の FindBugs は実行不可能な例外経路を刈り取れていないので、誤検出かもしれないことに注意してください。

switch 文の default が多くの場合実行不可能なので FindBugs が例外経路である default を検討することに注意して下さい。

]]>
null になっている可能性があるメソッドの戻り値を利用している null になっている可能性があるメソッドの戻り値を利用しています。{1}
メソッドからの戻り値を null チェックしないで利用しています。メソッドの戻り値は null なのかチェックするべきです。 コードが実行されると NullPointerException を引き起こすことがあります。

]]>
非 null パラメータに null を渡している非仮想メソッドの呼び出し 非仮想メソッド {2.givenClass} の 非 null パラメータに null を渡して呼び出しています。{1}
null の可能性がある値が 非 null メソッドパラメータに渡されています。 パラメータは、常に非 null とすべきパラメータとしてアノテートされていたか、または解析が常に null 値を利用すると示していました。

]]>
メソッド呼び出しは非 null パラメータに対して null を渡している {2.givenClass} の 非 null パラメータに対して null を渡しています。{1}
すべての既知のターゲットメソッドが非 null であることをパラメータに要求する呼び出し場所で、おそらく null 値を渡しています。 パラメータは、常に非 null とすべきパラメータとしてアノテートされていたか、または解析が常に null 値を利用すると示していました。

]]>
メソッド呼び出しは非 null パラメータに対して null を渡している {2.givenClass} の 非 null パラメータに対して null を渡しています。{1}
このメソッド呼び出しは非 null メソッドパラメータに対して null 値を渡しています。 パラメータは、常に非 null とすべきパラメータとしてアノテートされていたか、または解析が常に null 値を利用すると示していました。

]]>
メソッド呼び出しは非 null パラメータに対して null を渡している {2.givenClass} の 非 null パラメータに対して null を渡しています。{1}
このメソッドは、非 null でなければならないメソッドのパラメータとして、null 値を渡しています。 このパラメータは、@Nonnull として明示的にアノテートされていたか、または解析が常に null 値を利用すると示していました。

]]>
null を返すかもしれないメソッドが @Nonnull 宣言されている {1} は、null を返すかもしれないのに @Nonnull 宣言されています。
このメソッドは、null 値を返すかもしれないのにメソッド (またはスーパークラスのメソッド) の戻り値に @Nonnull が宣言されています。

]]>
null を返すかもしれない clone メソッド {1} は、null を返すかもしれません。
この clone メソッドは、いくつかの条件で null を返すと思われます。 しかし、clone メソッドは決して null を返すのは許されません。 この経路が到達できないことを確信しているなら、代わりに AssertionError をスローしてください。

]]>
null を返すかもしれない toString メソッド {1} は、null を返すかもしれません。
この toString メソッドは、いくつかの条件で null を返すと思われます。 仕様を寛大に読むとこれが許されると解釈できるかもしれませんが、それはおそらく間違った考えで、他のコードが壊れる原因になる可能性があります。 null ではなく空の文字列または、いくつかの他の適切な文字列を返してください。

]]>
null 値を利用することが保証されている {2.givenClass} は、null 値を利用することが保証されています。{1}
文または分岐が実行されるなら、この時点で値は null であり、null 値を利用する (フォワードパスで実行時例外を伴うこと以外は) ことが保証されています。

なお、if (x == null) throw new NullPointerException();x の参照解除として扱われることに注意して下さい。

]]>
null 値を例外経路で利用することが保証されている {2.name} は、例外経路で null 値を利用することが保証されています。{1}
例外経路上の文または分岐が実行されるなら、この時点で値は null であり、null 値を利用する (フォワードパスで実行時例外を伴うこと以外は) ことが保証されています。

]]>
スタティックイニシャライザは、すべての static final フィールドが代入される前にインスタンスを作成する {0} のためのスタティックイニシャライザは、すべての static final フィールドが代入される前にインスタンスを作成します。
すべての static final フィールドが初期化される前にスタティックイニシャライザがクラスのインスタンスを作成します。

]]>
ストリームのクローズに失敗するかもしれないメソッド {1} は、ストリームのクローズに失敗するかもしれません。
このメソッドは、入出力ストリームオブジェクトを作成していますが、どんなフィールドにも代入していないしクローズするかもしれない別のメソッドにも渡していなくて、戻り値にしてもいません。そして、メソッドからのすべての経路でクローズするように見えません。 これはファイルディスクリプタリークの原因になることがあります。 ストリームがクローズされることを確実にするために finally ブロックを使用することは一般的に良い考えです。

]]>
例外経路でストリームのクローズに失敗するかもしれないメソッド {1} は、例外経路でストリームのクローズに失敗するかもしれません。
このメソッドは、入出力ストリームオブジェクトを作成していますが、どんなフィールドにも代入していないしクローズするかもしれない別のメソッドにも渡していないくて、戻り値にしてもいません。そして、メソッドからのすべての可能性がある例外経路でクローズするように見えません。 これはファイルディスクリプターリークの原因になることがあります。 ストリームがクローズされることを確実にするために finally ブロックを使用することは一般的に良い考えです。

]]>
null ではなく長さが0の配列を返すことを検討する {1} は、null ではなく長さが0の配列を返すべきではありませんか?
結果がないこと (すなわち、結果の空のリスト) を示すために null 参照ではなく長さが0の配列 を返すことは、多くの場合より良い設計です。

他方では、「この質問に対する答えがない」ことを示すために null を使用することはおそらく適切です。 たとえば、File.listFiles() は、ファイルがないディレクトリを与えられた場合は空のリストを返し、ファイルがディレクトリでないなら null を返します。

]]>
役に立たない制御フロー 役に立たない制御フローです。{1}
このメソッドには分岐するのかどうかに関係なく、制御フローが同じ場所へと続く、役に立たない制御フロー文があります。
たとえば、これは 空の if 文が原因になります。

if (argv.length == 0) {
    // TODO: handle this case
}
]]>
次の行へ続くだけの役に立たない制御フロー 次の行に続くだけの役に立たない制御フローです。{1}
このメソッドには分岐するのかどうかに関係なく、制御フローが同じか次の行へと続く、役に立たない制御フロー文があります。
多くの場合、不注意に if 文の本体を空文を使用したことが原因になります。

if (argv.length == 1);
    System.out.println("Hello, " + argv[0]);
]]>
既に利用していた値の null チェック 既に利用していた {2.givenClass} の値を {4.lineNumber} で null チェックしています。{1}
ここで値が null なのかチェックしていますが、既に値を利用していたので null である可能性はありません。 値が null なら以前の利用で NullPointerException が発生していたでしょう。 基本的に、値が null であることを許すのかどうかに関係なく、このコードと以前の値の利用は一致しません。 チェックは冗長か、または以前の値の利用は誤りです。

]]>
null とわかっている値の冗長な null チェック null とわかっている値 {2} の冗長な null チェックがあります。{1}
このメソッドにはnull とわかっている値の冗長な null チェックがあります。

]]>
null でないことがわかっている値の冗長な null チェック null でないことがわかっている値 {2} の冗長な null チェックがあります。{1}
このメソッドには null でないことがわかっている値の冗長な null チェックがあります。

]]>
2つの null 値の冗長な比較 2つの null 値の冗長な比較があります。{1}
このメソッドには両方とも明らかに null とわかっている2つの参照の冗長な比較があります。

]]>
非 null 値と null 値との冗長な比較 非 null 値と null 値との冗長な比較があります。{1}
このメソッドにはnull でないことがわかっている参照と null とわかっている別の参照との比較があります。

]]>
Redundant comparison to null of previously checked value Redundant comparison to null of previously checked {2} in {1}
This method contains a redundant comparison of a reference value to null. Two types of redundant comparison are reported:

  • Both values compared are definitely null
  • One value is definitely null and the other is definitely not null

This particular warning generally indicates that a value known not to be null was checked against null. While the check is not necessary, it may simply be a case of defensive programming.

]]>
すべての経路でロックが解除されないメソッド {1} は、すべての経路でロックが解除されません。
このメソッドは、JSR-166(java.util.concurrent) のロックを獲得していますが、メソッドからのすべての経路で解除していません。 一般的に JSR-166のロックを使用するための正しいイディオムは以下のようになります。

Lock l = ...;
l.lock();
try {
    // do something
} finally {
    l.unlock();
}
]]>
すべての例外経路でロックが解除されないメソッド {1} は、すべての例外経路でロックが解除されません。
このメソッドは、JSR-166(java.util.concurrent) のロックを獲得していますが、メソッドからのすべての例外経路で解除していません。 一般的に JSR-166のロックを使用するための正しいイディオムは以下のようになります。

Lock l = ...;
l.lock();
try {
    // do something
} finally {
    l.unlock();
}
]]>
疑わしい参照比較 {2} の参照比較は疑わしいです。{1}
このメソッドは、 == または != 演算子を使用して2つの参照値を比較しています。 一般的にこの型のインスタンスを比較する正しい方法は equals メソッドです。 等価で識別可能なインスタンスを作成する可能性がありますが異なるオブジェクトなので == で比較しないでください。 参照によって一般に比較されるべきでないクラスの例は、java.lang.Integerjava.lang.Float などです。

]]>
定数への疑わしい参照比較 {2} 定数の参照比較は疑わしいです。{1}
このメソッドは、 参照値を == または != 演算子を使用して定数と比較しています。 一般的にこの型のインスタンスを比較する正しい方法は equals メソッドです。 等価で識別可能なインスタンスを作成する可能性がありますが異なるオブジェクトなので == で比較しないでください。 一般的に参照によって比較されるべきではないクラスの例は、java.lang.Integerjava.lang.Float などです。

]]>
Boolean 値の疑わしい参照比較 Boolean 値の疑わしい参照比較です。{1}
このメソッドは、== または != 演算子を使用して2つの Boolean 値を比較しています。 一般的には2つの Boolean 値 (Boolean.TRUEBoolean.FALSE) だけですが、 new Boolean(b) コンストラクタを使用して他の Boolean オブジェクトを作成する可能性があります。 そのようなオブジェクトを回避することは最高です。 しかし、それらが存在するなら、Boolean オブジェクトの等価性をチェックするために .equals(...) ではなく == または != を使用しているなら異なる結果をもたらします。

]]>
参照等価性を使用して異なる型を比較している {2.givenClass} を {3.givenClass} と比較するために参照等価性を使用しています。{1}
このメソッドは異なる型と思われる2つの参照を比較するために参照等価性を使用しています。 この比較の結果は、常に false です。

]]>
equals メソッドを呼び出して異なる型を比較している {3.simpleClass}.equals({2.simpleClass}) を呼び出しています。{1}
このメソッドは、異なるクラス型の2つの参照で equals(Object) メソッドを呼び出していて、解析が実行時に異なるクラスのオブジェクトになることを示唆しています。 さらに、呼び出されるであろう equals メソッドの検査では、この呼び出しは常に false を返すか、 あるいは equals メソッドが対称 (Object クラスの equals のための契約に必要な性質) ではないことのどちらかを示唆しています。

]]>
equals メソッドを呼び出して異なる型のインタフェースを比較している {3.simpleClass}.equals({2.simpleClass}) を呼び出しています。{1}
このメソッドは、どちらも他方のサブタイプでない無関係なインタフェース型の2つの参照で equals(Object) メソッドを呼び出しています。 そして、両方のインタフェースを実装する既知の非抽象クラスがありません。 したがって比較されている2つのオブジェクトは実行時に同じクラスのメンバである可能性が低いです (いくつかのアプリケーションクラスが解析できなかったか、動的クラスローディングが実行時に起こることができた場合を除く)。 equals メソッドの規約によると、異なるクラスのオブジェクトは常に等しくないとして比較するべきです。 したがって、java.lang.Object.equals(Object) によって定義される規約によれば、この比較の結果は実行時に常に false になります。

]]>
equals メソッドを呼び出して無関係のクラスとインタフェースを比較している {3.simpleClass}.equals({2.simpleClass}) を呼び出しています。{1}
このメソッドは、一方がクラスで他方がインタフェースである2つの参照で equals(Object) メソッドを呼び出しています。 クラスは、そのクラスの非抽象サブクラスも含めてインタフェースを実装していません。 したがって比較されている2つのオブジェクトは実行時に同じクラスのメンバである可能性が低いです (いくつかのアプリケーションクラスが解析できなかったか、動的クラスローディングが実行時に起こることができた場合を除く)。 equals メソッドの規約によると、異なるクラスのオブジェクトは常に等しくないとして比較するべきです。 したがって、java.lang.Object.equals(Object) によって定義される規約によれば、この比較の結果は実行時に常に false になります。

]]>
equals(null) の呼び出し equals(null) の呼び出し。
このメソッドは、 null 値の引数を渡して equals(Object) を呼び出しています。 equals メソッドの規約によると、この呼び出しは常に false を返すはずです。

]]>
不整合な wait メソッド 不整合な wait メソッドです。{1}
このメソッドは、オブジェクトで明らかにロックを保持することなく、Object.wait() を呼び出しています。 保持されるロックがない状態で、wait メソッドを呼び出すことは、IllegalMonitorStateException をスローすることになります。

]]>
不整合な notify メソッド 不整合な notify メソッドです。{1}
このメソッドは、オブジェクトで明らかにロックを保持することなく Object.notify()Object.notifyAll() を呼び出しています。 保持されるロックがない状態で、notify メソッドや notifyAll メソッドを呼び出すことは、IllegalMonitorStateException をスローすることになります。

]]>
フィールドへの代入ではなくローカル変数への自己代入 フィールドへの代入ではなく、{2} の自己代入です。{1}
このメソッドにはローカル変数の自己代入があり、ローカル変数とフィールドが同じ名前です。
たとえば以下のようなコードです。

    int foo;
    public void setFoo(int foo) {
        foo = foo;
    }

そのような代入は役に立ちません。そうではなく、フィールドに代入するつもりでしたか?

]]>
ローカル変数の自己代入 {2} の自己代入です。{1}
このメソッドにはローカル変数の自己代入があります。
たとえば以下のようなコードです。

public void foo() {
    int x = 3;
    x = x;
}

そのような代入は役に立たないので、論理エラーかタイプミスかもしれません。

]]>
フィールドの自己代入 フィールド {2.givenClass} の自己代入です。{1}
このメソッドにはフィールドの自己代入があります。
たとえば以下のようなコードです。

int x;
public void foo() {
    x = x;
}

そのような代入は役に立たないので、論理エラーかタイプミスかもしれません。

]]>
フィールドの二重代入 フィールド {2.givenClass} の二重代入です。{1}
このメソッドにはフィールドの二重代入があります。
たとえば以下のようなコードです。

int x,y;
public void foo() {
    x = x = 17;
}

フィールドに2回代入することは役に立たないので、論理エラーかタイプミスかもしれません。

]]>
ローカル変数の二重代入 ローカル変数 {2} の二重代入です。{1}
このメソッドにはローカル変数の二重代入があります。
たとえば以下のようなコードです。

public void foo() {
    int x,y;
    x = x = 17;
}

変数に同じ値を2回代入することは役に立たないので、論理エラーかタイプミスかもしれません。

]]>
フィールドの無意味な自己演算 (たとえば、 x & x) {2.givenClass} とそれ自身との無意味な自己演算です。
このメソッドは、フィールドと同じフィールドへの別の参照との無意味な計算を実行しています (たとえば、x & x または x - x)。 この計算の性質のため、演算は意味をなすとは思われないので、論理エラーかタイプミスかもしれません。 計算をチェックしてください。

]]>
変数の無意味な自己演算 (たとえば、x & x) {2} とそれ自身との無意味な自己演算です。{1}
このメソッドは、ローカル変数と同じ変数への別の参照との無意味な計算を実行しています (たとえば、x & x または x - x)。 この計算の性質のため、演算は意味をなすとは思われないので、論理エラーかタイプミスかもしれません。 計算をダブルチェックしてください。

]]>
フィールドとそれ自身との自己比較 {2.givenClass} とそれ自身との自己比較です。{1}
このメソッドは、フィールドをそれ自身と比較しています。 論理エラーかタイプミスかもしれません。正しいものを比較していることを確認してください。

]]>
ローカル変数とそれ自身との自己比較 {2.givenClass} とそれ自身との自己比較です。{1}
このメソッドは、ローカル変数をそれ自身と比較しています。論理エラーかタイプミスかもしれません。 正しいものを比較していることを確認してください。

]]>
int に対して Double.longBitsToDouble() を呼び出している int に対して Double.longBitsToDouble() を呼び出しています。{1}
Double.longBitsToDouble() の呼び出しで、32ビット int 値が引数として渡されています。 これはほぼ間違いなく意図したことではありませんし意図した結果を与えることはほとんどありません。

]]>
逆にされた引数 {2.name} の呼び出しのための間違った順序の引数。{1}
このメソッド呼び出しへの引数は、順序が間違っているように見えます。 たとえば、呼び出し Preconditions.checkNotNull("message", message) は、引数を予約しました。チェックされる値は第一引数です。

]]>
Random オブジェクトが作成され1度しか使われない Random オブジェクトが生成され、1度しか使われていません。{1}
このコードは java.util.Random オブジェクトを作成して1つの乱数を生成するために使用して捨てています。 これはあまり良くない品質の乱数を作り出し、効率が悪いです。 できれば、Random オブジェクトを1つだけ作成して保存されるようにコードを書き直してください。 そして、毎回新しい乱数は既存の Random オブジェクトを呼び出して取得することが必要です。

生成された乱数が推測可能でないことが重要なら、乱数ごとに新しい Random オブジェクトを作成してはいけません (値はあまりに簡単に推測可能です)。 その代わりに java.security.SecureRandom の使用を強く検討するべきです (そして必要とされる乱数ごとに新しい SecureRandom のオブジェクトを作成することを回避します)。

]]>
符号付き整数の乱数の絶対値を計算する間違った試み 符号付き整数の乱数の絶対値を計算する間違った試みです。{1}
このコードは符号付き整数の乱数を生成して絶対値を計算しています。 乱数ジェネレータで返される数が Integer.MIN_VALUE なら結果は同様に負です (Math.abs(Integer.MIN_VALUE) == Integer.MIN_VALUE なので)。 (同じ問題は long 値でも同様に起きます)。

]]>
符号付き32ビットハッシュコードの絶対値を計算する間違った試み 符号付き32ビットハッシュコードの絶対値を計算する間違った試みです。{1}
このコードはハッシュコードを生成して絶対値を計算しています。 ハッシュコードが Integer.MIN_VALUE なら結果は同様に負です (Math.abs(Integer.MIN_VALUE) == Integer.MIN_VALUE なので)。

文字列の2^32個に1個は Integer.MIN_VALUE のハッシュコードを持っていて、「polygenelubricants」、「GydZG_」、「DESIGNING WORKHOUSES」が該当します。

]]>
符号付き32ビット整数の乱数の剰余 符号付き32ビット整数の乱数の剰余を計算しています。{1}
このコードは符号付き整数の乱数を生成して別の値を法とする剰余を計算しています。 乱数は負になり、剰余演算の結果も負になります。これが意図したことであることを確実にしてください。 その代わりに Random.nextInt(int) の使用を強く検討してください。

]]>
ハッシュコードの剰余は負かもしれない ハッシュコードの剰余は負かもしれません。{1}
このコードはハッシュコードを計算して別の値を法とする剰余を計算しています。 ハッシュコードは負になり、剰余演算の結果も負なります。

計算結果が負ではないことを確認したいなら、コードを変更する必要があるかもしれません。 除数が2の累乗であることがわかっているなら、代わりにビット演算を使用できます (すなわち、x.hashCode()%n の代わりに x.hashCode()&(n-1) を使用してください)。 これはおそらく、剰余を計算するより高速です。 除数が2の累乗であるということをわかっていないなら、剰余演算の結果の絶対値を取得してください (すなわち Math.abs(x.hashCode()%n))。

]]>
負でない値と負の定数またはゼロとの間違った比較 負でない値 と {2} との間違った比較です。{1}
このコードは負でないことが保証されている値と負の定数またはゼロとを比較しています。

]]>
符号付きバイトの間違った比較 符号付きバイト と {2} との間違った比較です。{1}
符号付バイトのとりうる値の範囲は-128~127です。その範囲外で符号付バイトを値と比較することは無意味で間違っていそうです。 符号付きバイト b を範囲が0~255の符号なしバイトに変換するには 0xff & b を使用してください。

]]>
int 値と long 定数との間違った比較 int 値と {2} との間違った比較です。{1}
このコードはint 値と int 値として表される値の範囲外の long 定数を比較しています。 この比較は無意味で、おそらく間違っています。

]]>
整数値の無意味なビットマスク演算 {3} の無意味な {2} 演算です。{1}
どんな有用な仕事もしない整数ビット演算 (AND、OR、XOR) です (たとえば v & 0xffffffff)。

]]>
整数値の無意味な比較 整数値の無意味な比較です。{1}
常に同じ値を返す整数の比較があります (たとえば x <= Integer.MAX_VALUE)。

]]>
1を法とする整数の剰余 1を法とする整数の剰余を計算しています。{1}
どんな式 (exp % 1) も常に0を返すことが保証されています。 そうではなく、(exp & 1) または (exp & 2) を意味していましたか?

]]>
符号付きバイト値のビット論理和 符号付きバイト値のビット論理和を計算しています。{1}
ロードしたバイト値 (たとえば、バイト配列からロードされた値や戻り値がバイト型のメソッドから返された値) とビット論理和を実行しています。 ビット演算を実行する前にバイト値は32ビットまで符号拡張されます。 したがって、b[0] の値が 0xff で、x の初期値が 0 だとすると、 ((x << 8) | b[0]) は、0xff が符号拡張で 0xffffffff になるので、結果として 0xffffffff が得られます。

特に、バイト配列 int にパックする以下のようなコードはひどく間違っています。

int result = 0;
for(int i = 0; i < 4; i++) {
    result = ((result << 8) | b[i]);
}

その代わりに以下のようなイディオムは動作します。

int result = 0;
for(int i = 0; i < 4; i++) {
    result = ((result << 8) | (b[i] & 0xff));
}
]]>
符号付きバイト値のビット加算 符号付きバイト値のビット加算を計算をしています。{1}
バイト値と明らかに下位8ビットがあるとわかっている値を加算しています。 ビット演算を実行する前にバイト配列からロードされた値は32ビットまで符号拡張されます。 したがって、b[0] の値が 0xff で、x の初期値が 0 だとすると、 ((x << 8) + b[0]) は、0xff が符号拡張で 0xffffffff になるので、結果として 0xffffffff が得られます。

特に、バイト配列 int にパックする以下のようなコードはひどく間違っています。

int result = 0;
for(int i = 0; i < 4; i++) 
  result = ((result << 8) + b[i]);

その代わりに以下のようなイディオムは動作します。

int result = 0;
for(int i = 0; i < 4; i++) 
  result = ((result << 8) + (b[i] & 0xff));
]]>
互換性のないビットマスク (e & {2} == {3}) の互換性のないビットマスクは、不変の結果をもたらします。{1}
このメソッドは、(e & C) 形式の式を D と比較しています。 定数 C の特定の値と D ために常に等しくないことを比較します。論理エラーかタイプミスかもしれません。

]]>
ビット演算の符号をチェックする ビット演算の符号をチェックしてください。{1}
このメソッドは、((event.detail & SWT.SELECTED) > 0) のような式で比較しています。 ビット演算をより大きい演算子で比較することは、予想外の結果 (もちろん、SWT.SELECTED の値による) の原因になる可能性があります。 SWT.SELECTED が負数であるなら、これはバグの候補です。 SWT.SELECTED が負ではないとしても、'> 0' の代わりに '!= 0' を使用することが良いプラクティスであると思われます。

]]>
負数を含むビット演算の符号をチェックする {2} を含むビット演算の符号をチェックしてください。{1}
このメソッドは、CONSTANT が負数のときに ((val & CONSTANT) > 0) のようなビット演算式で比較しています。 ビット演算をより大きい演算子で比較することは、予想外の結果の原因になる可能性があります。比較は期待したようになりません。 '> 0' の代わりに '!= 0' を使用することが良いプラクティスです。

]]>
((...) & 0) == 0 なのか確かめている ((...) & 0) == 0 なのか確かめています。{1}
このメソッドは、(e & 0) 形式の式を0と比較しています。それは、常に等価であることを比較します。論理エラーかタイプミスかもしれません。

]]>
互換性のないビットマスク (e | {2} == {3}) の互換性のないビットマスクは、不変の結果をもたらします。{1}
このメソッドは、(e | C) 形式の式を D と比較しています。 定数 C と D の特定の値のために常に等しくないことを比較します。論理エラーかタイプミスかもしれません。

典型的に、このバグは、ビットセットで帰属関係のテストを実行したいコードで発生します。 しかし、ビット論理積演算子 ("&") の代わりにビット論理和演算子 ("|") を使用しています。

こうしたバグは (e & (A | B)) == C が意図されている間に ((e & A) | B) == C のように解析される (e & A | B) == C のような式で現れるかもしれません。

]]>
Incorrect lazy initialization of instance field Incorrect lazy initialization of instance field {2} in {1}
This method contains an unsynchronized lazy initialization of a non-volatile field. Because the compiler or processor may reorder instructions, threads are not guaranteed to see a completely initialized object, if the method can be called by multiple threads. You can make the field volatile to correct the problem. For more information, see the Java Memory Model web site.

]]>
static フィールドの間違った遅延初期化 static フィールド {2} の間違った遅延初期化。{1}
このメソッドにはvolatile でない static フィールドの非同期な遅延初期化があります。 コンパイラやプロセッサが命令を並べ替えるかもしれないので、メソッドが複数のスレッドによって呼び出されるなら、 スレッドは完全に初期化されたオブジェクトを見るとは保証されていません。 フィールドにアクセスした際に、中途半端に初期化されたインスタンスが見えてしまう危険があります。 この問題を修正するためにフィールドを volatile にできます。
詳細は、Java Memory Model web site を参照してください。

]]>
更新される static フィールドの間違った遅延初期化 更新される static フィールド {2} の間違った遅延初期化。{1}
このメソッドにはstatic フィールドの非同期な遅延初期化があります。 フィールドが設定された後で、その場所に格納されるオブジェクトはさらに更新されるかアクセスされます。 それが設定されるとすぐに、フィールドを設定することは他のスレッドに見えます。 フィールドを設定するさらなるアクセスがオブジェクトを初期化するのに役に立つなら、 それが完全に初期化されるまでどんな他のスレッドも格納されたオブジェクトにアクセスするのを防がないかぎり、非常に深刻なマルチスレッドバグがあります。

たとえメソッドが複数のスレッドによって決して呼び出されないと確信していても、 それは、フィールドに設定している値が完全にデータを読み込まれるか初期化されるまで、 static フィールドを設定しないほうが良いかもしれません。

]]>
Lock で同期化している {2} で同期化しています。{1}
このメソッドは、java.util.concurrent.locks.Lock を実装したオブジェクトで同期化しています。 そのようなオブジェクトは synchronized (...) 構文よりも acquire()/release() を使用してロックとロックの解除をします。

]]>
util.concurrent 抽象でモニタスタイルの wait メソッドを使用している {3.name} ではなく {2.name} を呼び出しています。{1}
このメソッドは、await() メソッド、signal メソッド、signalAll メソッドを提供するオブジェクト (たとえば、util.concurrent の Condition オブジェクト) で、wait メソッド、notify メソッド、notifyAll メソッドを呼び出しています。 これはおそらくあなたが望むことではありません。たとえそれを望むとしても、他の開発者が非常に紛らわしいことを理解して、設計を変更することを検討するべきです。

]]>
java.util.concurrent のインスタンスで同期化している {2} で同期化しています。{1}
このメソッドは、java.util.concurrent パッケージのクラス (またはサブクラス) のインスタンスで同期化しています。 これらのクラスのインスタンスは、synchronized の使用とは違う互換性のないそれら自身の並行制御メカニズムを持っています。 たとえば、AtomicBoolean で同期しても、他のスレッドが AtomicBoolean を変更するのを防ぎません。

そのようなコードは正しいかもしれないが、将来コードを維持しなければならない人々を混乱させるかもしれないので慎重にレビューし文書化するべきです、

]]>
private メソッドは決して呼び出されない {1} は、決して呼び出されません。
この private メソッドは、決して呼び出されません。 メソッドがリフレクションによって呼び出されるかもしれないが、決して使われないなら除去するべきです。

]]>
呼び出し不可能なメソッドが無名クラスで定義されている 呼び出し不可能なメソッド {1} が無名クラスで定義されています。
この無名クラスは、直接呼び出されないスーパークラスのメソッドをオーバーライドしていないメソッドを定義しています。 他のクラスのメソッドが無名クラスで宣言されたメソッドを直接呼び出せないので、このメソッドは呼び出し不可能だと思われます。 メソッドは単にデッドコードであるかもしれません。しかし、メソッドがスーパークラスで宣言されるメソッドをオーバーライドすることを意図した可能性もあります。 そして、タイプミスまたは他の誤りのためにメソッドは、実際には意図しているメソッドをオーバーライドしません。

]]>
データベースリソースのクローズに失敗するかもしれないメソッド {1} は、{2.excludingPackage} のクローズに失敗するかもしれません。
このメソッドは、データベースリソース (たとえば、データベースコネクションや行セット) を作成していますが、どんなフィールドにも代入していないか、他のメソッドにも渡していないか、戻り値にもしていません。 そして、メソッドからのすべての経路でオブジェクトをクローズするように見えません。 メソッドからのすべての経路でデータベースリソースのクローズが失敗すると性能低下になることがあります。 データベースとの通信で問題があるアプリケーションの原因になる可能性があります。

]]>
例外経路でデータベースリソースのクローズに失敗するかもしれないメソッド {1} は、例外経路でデータベースリソースのクローズに失敗するかもしれません。
このメソッドは、データベースリソース (たとえば、データベースコネクションや行セット) を作成していますが、どんなフィールドにも代入していないか、他のメソッドにも渡していないか、戻り値にもしていません。 そして、メソッドからのすべての例外経路でオブジェクトをクローズするように見えません。 メソッドからのすべての経路でデータベースリソースのクローズが失敗すると性能低下になることがあります。 データベースとの通信で問題があるアプリケーションの原因になる可能性があります。

]]>
ループの中で + を使用して文字列を連結しているメソッド {1} は、ループの中で + を使用して文字列を連結しています。
このメソッドは、ループの中で + を使用して String を構築していると思われます。 各々の繰り返しにおいて、StringStringBuffer/StringBuilder に変換、追加され、String へ変換されます。 各々の繰り返しで文字列が再コピーされ、増大すると繰り返しの数で二次コストの原因になる可能性があります。

StringBuffer (または J2SE 5.0の StringBuilder) を明示的に使うとより良い性能を得られます。

たとえば、

// This is bad
String s = "";
for (int i = 0; i < field.length; ++i) {
    s = s + field[i];
}

// This is better
StringBuffer buf = new StringBuffer();
for (int i = 0; i < field.length; ++i) {
    buf.append(field[i]);
}
String s = buf.toString();
]]>
ループの中で prepareStatement を呼び出しているメソッド {1} は、ループの中で不変の引数で prepareStatement を呼び出しています。
メソッドは、ループの中で Connection.prepareStatement に不変の引数を渡して呼び出しています。 PreparedStatement を複数回実行する必要があるなら、それぞれのループの繰り返しで再生成する理由がありません。 ループの外に呼び出しを移動します。

]]>
ループの中で NodeList.getLength() を呼び出しているメソッド {1} は、ループの中で getElementsByTagName の戻り値のために NodeList.getLength() を呼び出しています。
メソッドは、ループの中で NodeList.getLength() を呼び出し、NodeList は、getElementsByTagName の呼び出しによって作られます。 NodeList は長さを格納しませんが、毎回とても最適ではない方法で計算されます。 ループの前に変数に長さを格納することを検討してください。

]]>
ループの中で Pattern.compile を呼び出しているメソッド {1} は、ループの中で不変の定数で Pattern.compile を呼び出しています。
メソッドは、ループの中で Pattern.compile に不変の定数を渡して呼び出しています。 Pattern を複数回使用する必要があるなら、それぞれのループの繰り返しでコンパイルする理由がありません。 ループの外に呼び出しを移動するか static final フィールドにします。

]]>
ループの中で正規表現をコンパイルしているメソッド {1} は、ループの中で正規表現のコンパイルをしています。
メソッドは、ループの中で同じ正規表現を生成しているので、繰り返しごとにコンパイルされます。 ループの外で Pattern.compile を使用して正規表現をプリコンパイルするのが最適でしょう。

]]>
String.indexOf(String) の非効率的な使用 {1} は、String.indexOf(int) の代わりに String.indexOf(String) を使用しています。
このコードはString.indexOf() に長さ1の文字列定数を渡しています。String.indexOf() の整数実装を使うほうが効率的です。 たとえば、myString.indexOf(".") の代わりに myString.indexOf('.') を呼び出します。

]]>
String.lastIndexOf(String) の非効率的な使用 {1} は、String.lastIndexOf(int) の代わりに String.lastIndexOf(String) を使用しています。
このコードはString.lastIndexOf() に長さ1の文字列定数を渡しています。String.lastIndexOf() の整数実装を使うほうが効率的です。 たとえば、myString.lastIndexOf(".") の代わりに myString.lastIndexOf('.') を呼び出します。

]]>
長さが0の配列の引数で toArray メソッドを使用しているメソッド {1} は、長さが0の配列の引数で Collection.toArray() を使用しています。
このメソッドは、Collection 派生クラスの toArray メソッドを使用して長さが0の配列の引数を渡しています。 myCollection.toArray(new Foo[myCollection.size()]) を使用するほうがより効率的です。 渡される配列がコレクションの要素のすべてを格納できるくらいの大きさなら、データが読み込まれて、そのまま返されます。 これは結果として返す2番目の配列 (リフレクションによって) を作成する必要を回避します。

]]>
run メソッドでの JUnit アサーションは JUnit によって通知されない {1} での JUnit アサーションは JUnit によって通知されません。
run メソッドで JUnit アサーションが実行されています。失敗した JUnit アサーションは例外をスローします。 したがって、この例外がテストメソッドを実行したスレッド以外のスレッドで発生するなら、例外はスレッドを終了させますが、テストの失敗になりません。

]]>
TestCase は super.setup() を呼び出さない setUp メソッドを実装している TestCase {0} は、super.setup() を呼び出さない setUp メソッドを定義しています。
JUnit の TestCase クラスで、setUp メソッドを実装しています。 setUp メソッドは、super.setUp() を呼び出すべきなのにそうしていません。

]]>
TestCase は super.tearDown() を呼び出さない tearDown メソッドを実装している TestCase {0} は、super.tearDown() を呼び出さない tearDown メソッドを実装しています。
JUnit の TestCase クラスで、tearDown メソッドを実装しています。 tearDown メソッドは、super.tearDown() を呼び出すべきなのにそうしていません。

]]>
TestCase は 非 static な suite メソッドを実装している TestCase {0} は、非 static な suite メソッドを実装しています。
JUnit の TestCase クラスで、suite メソッドを実装しています。 suite メソッドは static として宣言するべきなのにそうしていません。

]]>
TestCase は suite メソッドの間違った宣言をしている TestCase {0} は、suite メソッドの間違った宣言をしています。
JUnit の TestCase クラスで、suite メソッドを実装しています。 しかしながら、suite メソッドは、

public static junit.framework.Test suite()

public static junit.framework.TestSuite suite()

のどちらかを宣言する必要があります。

]]>
TestCase はテストがない TestCase {0} は、テストがありません。
JUnit の TestCase クラスで、どんなテストメソッドも実装していません。

]]>
スーパークラスの Adapter で実装されるメソッドを誤ってオーバーライドしているクラス クラス {0} は、スーパークラス の Adapter で実装されるメソッド {1} を誤ってオーバーライドしています。
このメソッドは、スーパークラスで実装されているメソッドをオーバーライドしています。 スーパークラスは、java.awt.event や javax.swing.event パッケージで定義されているリスナを実装する Adapter です。 その結果、イベントが発生するときこのメソッドは呼び出されません。

]]>
Method attempts to access a result set field with index 0 {1} attempts to access a result set field with index 0
A call to getXXX or updateXXX methods of a result set was made where the field index is 0. As ResultSet fields start at index 1, this is always a mistake.

]]>
インデックスが0で ResultSet にアクセスしようとしているメソッド {1} は、インデックスが0で ResultSet にアクセスしようとしています。
インデックスが0で、ResultSet の getXXX、updateXXX メソッドを呼び出しています。 ResultSet のインデックスは1から開始するので、これは常に間違いです。

]]>
インデックスが0で PreparedStatement にアクセスしようとしているメソッド {1} は、インデックスが0で PreparedStatement にアクセスしようとしています。
インデックスが0で、PreparedStatement の setXXX メソッドを呼び出しています。 インデックスは1から開始するので、これは常に間違いです。

]]>
instanceof 演算子を使用した不必要な型チェック {1} は、静的に判定される instanceof 演算子を使用して不必要な型チェックをしています。
オブジェクトが要求する型であるかどうかにかかわらず、静的に判定される instanceof 演算子を使用して型チェックをしています。

]]>
初期化されていない AppletStub に依存する間違ったアプレットコンストラクタ 間違ったアプレットコンストラクタは、初期化されていない AppletStub に依存しています。
このコンストラクタは、AppletStub に依存する親アプレットでメソッドを呼び出しています。 このアプレットの init メソッドが呼び出されるまで AppletStub は初期化されないので、これらのメソッドは正しく機能しません。

]]>
equals メソッドを使用して配列と非配列を比較している {3.simpleClass}.equals({2.simpleClass}) を呼び出しています。{1}
このメソッドは、配列と配列だと思われない参照を比較するために .equals(Object o) を呼び出しています。 比較されているものが違う型なら等しくないことであることが保証されているので、比較はほぼ間違いなく誤りです。 たとえそれらが両方とも配列だったとしても、配列の equals メソッドは2つの配列が同じオブジェクトだと決定するだけです。 配列のコンテンツを比較するためには java.util.Arrays.equals(Object[], Object[]) を使用してください。

]]>
配列の equals メソッド呼び出しは == と等価である {2.simpleClass} を比較するために .equals を使用していますが、== と等価です。{1}
このメソッドは、配列で .equals(Object o) を呼び出しています。 配列は、Objectequals メソッドをオーバーライドしないので、配列で equals メソッドを呼び出すことはアドレスを比較することと同じです。 配列のコンテンツを比較するためには java.util.Arrays.equals(Object[], Object[]) を使用してください。 配列のアドレスを比較するために明示的に == を使用して参照等価性をチェックすることは、それほど紛らわしくないでしょう。

]]>
equals(...) メソッドを使用して互換性のない配列を比較している {2.simpleClass} と {3.simpleClass} を比較するために equals メソッドを使用しています。{1}
このメソッドは、互換性のない型の配列を比較するために .equals(Object o) を呼び出しています (たとえば、String[]StringBuffer[]String[]int[]) 。 それらは、決して等価ではありません。 さらに、equals(...) が配列を比較するのに使用されるとき、それらが同じ配列であるかどうか確かめるだけで、配列のコンテンツは無視します。

]]>
interrupted メソッドを呼び出すために不要な currentThread メソッドを呼び出している {1} は、interrupted メソッドを呼び出すために不要な currentThread メソッドを呼び出しています。
このメソッドは、interrupted メソッドを呼び出すために Thread.currentThread() を呼び出しています。 interrupted メソッドは static メソッドなので、Thread.interrupted() を使用するほうが単純明解です。

]]>
スレッドインスタンスで static Thread.interrupted() を呼び出している {1}は、スレッドインスタンスで static Thread.interrupted() を呼び出しています。
このメソッドは、カレントスレッドでない Thread オブジェクトであるように見える Thread オブジェクトで Thread.interrupted() を呼び出しています。 interrupted メソッドは static なので、作成者が意図したこととは異なるオブジェクトで呼び出されます。

]]>
メソッドで読み取られずに上書きされているパラメータ {1} へのパラメータ {2} は、読み取られずに上書きされています。
このパラメータの初期値は無視され、ここで上書きされています。 これは多くの場合、パラメータへの書き込みが呼び出し元に戻されるという誤った考えを示しています。

]]>
フィールドを遮るローカル変数への無効な代入 同じ名前のフィールではなく、{2} への無効な代入です。{1}
この命令は、ローカル変数に値を代入していますが、値は読み出されないか以降の命令でも使われません。 多くの場合、計算された値が決して使われないので、これは誤りを示します。 フィールドがローカル変数と同じ名前です。そうではなく、フィールドに代入するつもりでしたか?

]]>
ローカル変数への無効な代入 {2} への無効な代入です。{1}
この命令はローカル変数に値を代入していますが、値は読み出されないか以降の命令でも使われません。 多くの場合、計算された値が決して使われないので、これは誤りを示します。

Sun の javac コンパイラが final なローカル変数のためにしばしば無効な格納を生成することに注意してください。 FindBugs は、バイトコードベースのツールなので誤検出をなくす簡単な方法がありません。

]]>
return 文に役に立たない代入がある {1} からの return 文に役に立たない代入があります。
この文は、return 文でローカル変数に代入をしています。この代入は効果がありません。 この文が正しいことを確かめてください。

]]>
return 文に無駄なインクリメントがある {1} からの return に無駄なインクリメントがあります。
return x++; のような return 文があります。 接頭辞インクリメント/デクリメントは 式の値に影響を与えないので、インクリメント/デクリメントは効果がありません。 この文が正しいのか確かめてください。

]]>
クラスリテラルの無効な代入 {3}.class の無効な代入です。{1}
この命令は変数にクラスリテラルを代入していますが、決して使われません。
The behavior of this differs in Java 1.4 and in Java 5
J2SE 1.4 およびそれ以前のバージョンでは、Foo.class への参照は Foo のためのスタティックイニシャライザが既に実行されていないなら実行することを強制します。 J2SE 5.0 ではそうしません。

より多くの詳細と例と J2SE 5.0 のクラスの強制的な初期化の方法の提案は Sun の article on Java SE compatibility を参照してください。

]]>
ローカル変数への無効な null 代入 {2} への無効な null 代入です。{1}
このコードはローカル変数に null を代入していますが代入された値は読み出されていません。 この代入はガベージコレクタを手伝うために導入されたのかもしれませんが、Java SE 6 ではもはや必要とされないか有用ではありません。

]]>
フィールドを隠す変数を定義しているメソッド {1} は、フィールド {2.givenClass} を隠す変数を定義しています。
このメソッドは、このクラスまたはスーパークラスのフィールドと同じ名前でローカル変数を定義しています。 フィールドから初期化されていない値を読み出す、初期化されていないフィールドをそのままにしておくか、または両方を引き起こすかもしれません。

]]>
スーパークラスのフィールドを隠すフィールドを定義しているクラス フィールド {1.givenClass} は、スーパークラス {2.class} のフィールドを隠しています。
このクラスは、スーパークラスの可視インスタンスフィールドと同じ名前でフィールドを定義しています。 これは紛らわしくて、メソッドがフィールドを更新するかアクセスするなら、間違いを指摘するかもしれません。

]]>
entrySet イテレータではなく効率が悪い keySet イテレータを使用している {1} は、entrySet イテレータではなく効率が悪い keySet イテレータを使用しています。
このメソッドは、keySet イテレータから取り出されたキーを使用して、マップエントリの値にアクセスしています。 Map の entrySet イテレータを使用したほうが Map.get(key) ルックアップを回避するのでより効率的です。

]]>
static メソッドだけを提供するクラスの不必要なインスタンス化 {1} は、static メソッドだけを提供するクラスを不必要にインスタンス化しています。
このクラスは、static メソッドだけを提供するクラスのオブジェクトを作成しています。 このオブジェクトは作成する必要はありません。修飾子として直接クラス名を使用する static メソッドにアクセスしてください。

]]>
例外がスローされないのに例外をキャッチしている 例外がスローされないのに例外をキャッチしています。{1}
このメソッドは、例外オブジェクトをキャッチする try-catch ブロックを使用していますが、例外は try ブロックの中でスローされません。また、実行時例外は明示的にキャッチされません。 それぞれの catch ブロックが同一である多くの例外型をキャッチすることの短縮形として try { ... } catch (Exception e) { something } を使用することが共通のバグパターンです。 しかし、この構文は誤って実行時例外も同様にキャッチするので、潜在的なバグを隠します。

より良いアプローチは、明示的にキャッチするよりもスローされる特定の例外をスローします。 あるいは、以下に示すように明示的に RuntimeException をキャッチ、再スローして、非実行時例外をキャッチします。

try {
    ...
} catch (RuntimeException e) {
    throw e;
} catch (Exception e) {
    ... deal with all non-runtime exceptions ...
}
]]>
NaN への等価性のための絶望的なテスト NaN への等価性のための絶望的なテストです。{1}
このコードは浮動小数点が特別な非数値と等価であるか確かめています (たとえば if (x == Double.NaN))。 しかしながら、NaN の特別な意味のため、値は NaN と等価ではありません。 したがって、x == Double.NaN は常に false と評価します。 x という値が特別な非数値であるかどうか確かめるためには Double.isNaN(x) を使用します (または x が浮動小数点精度であるなら Float.isNaN(x))。

]]>
浮動小数点の等価性のためのテスト 浮動小数点の等価性のためのテストです。{1}
この演算は、等価性のために2つの浮動小数点値を比較しています。 浮動小数点の計算は丸めを伴うかもしれないので計算された float と double の値は正確ではないかもしれません。 通貨のような正確でなければならない値のために BigDecimal のような固定精度型を使用することを検討してください。 正確である必要がない値のためにいくつかの範囲の中で等価性のために比較することを検討してください。 たとえば、if (Math.abs(x - y) < .0000001)
詳細は Java 言語仕様4.2.4を参照してください。

]]>
定数値で Math クラスの static メソッドを呼び出しているメソッド メソッドは、定数値で Math クラスの static メソッドを呼び出しています。
このメソッドは、定数値で java.lang.Math の static メソッドを呼び出しています。 このメソッドの結果は静的に判定でき、より高速で、ときには定数を使用するほうがより正確です。
検出されるメソッドは、以下のとおりです。

メソッド パラメータ
abs -any-
acos 0.0 or 1.0
asin 0.0 or 1.0
atan 0.0 or 1.0
atan2 0.0
cbrt 0.0 or 1.0
ceil -any-
cos 0.0
cosh 0.0
exp 0.0 or 1.0
expm1 0.0
floor -any-
log 0.0 or 1.0
log10 0.0 or 1.0
rint -any-
round -any-
sin 0.0
sinh 0.0
sqrt 0.0 or 1.0
tan 0.0
tanh 0.0
toDegrees 0.0 or 1.0
toRadians 0.0
]]>
クラス間の循環依存関係のテスト クラス {0} は、他のクラスと循環依存関係があります。
このクラスは、他のクラスと循環依存関係があります。 それぞれが他のクラスの正確な構築に依存していて、クラスの構築を難しくしています。 難しい依存関係を断つためにインタフェースの使用を検討してください。

]]>
スーパークラスと同じインタフェースを実装しているクラス クラス {0} は、スーパークラスと同じインタフェースを実装しています。
このクラスは、スーパークラスによっても実装されるインタフェースを実装することを宣言しています。 スーパークラスがインタフェースを実装するので、これは冗長です。デフォルトですべてのサブクラスもこのインタフェースを実装します。 このクラスが作成されてから継承階層が変わったことを指摘するかもしれません。インタフェースの実装の所有権を考慮するべきです。

]]>
Struts Action を拡張したクラスでのインスタンス変数の使用 Struts Action クラスを拡張したクラス {0} で、インスタンス変数を使用しています。
Struts Action クラスを拡張したクラスで、インスタンス変数を使用しています。 Struts Action クラスの1つのインスタンスだけが Struts フレームワークによって作成され、マルチスレッドによって使われるので、このパラダイムは極めて問題があり、推奨できません。 ローカル変数を使用することだけを検討してください。 モニタを除いて書き込まれるインスタンスフィールドだけが報告されます。

]]>
Servlet クラスを拡張したクラスでのインスタンス変数の使用 Servlet クラスを拡張したクラス {0} で、インスタンス変数を使用しています。
Servletクラスを拡張したクラスで、インスタンス変数を使用しています。 Servlet クラスの1つのインスタンスだけが Java EE フレームワークによって作成され、マルチスレッドによって使われるので、このパラダイムは極めて問題があり、推奨できません。 ローカル変数を使用することだけを検討してください。

]]>
公開インタフェースで同期化とセマフォを暴露するクラス クラス {0} は、公開インタフェースで同期化とセマフォを暴露しています。
このクラスは、自分自身 (this 参照) で、 wait メソッド、notify メソッド、notifyAll メソッド とともに同期化しています。 このクラスを使用するクライアントクラスは、同期化のためのオブジェクトとしてこのクラスのインスタンスをさらに使用するかもしれません。 2つのクラスが同期化のために同じオブジェクトを使用するので、マルチスレッドの正確性は疑わしいです。 同期化するべきでもないし、公開参照でセマフォメソッドも呼び出すべきではありません。 同期化の制御には内部の公開されないメンバ変数を使用することを検討してください。

]]>
整数乗算の結果を long にキャストしている 整数乗算の結果を long にキャストしています。{1}
このコードは以下のように整数の乗算を実行してから結果を long に変換しています。

long convertDaysToMilliseconds(int days) { return 1000*3600*24*days; } 

long を使用して乗算をすれば、結果がオーバーフローするという可能性を回避できます。
たとえば以下のように修正できます。

long convertDaysToMilliseconds(int days) { return 1000L*3600*24*days; } 

または

static final long MILLISECONDS_PER_DAY = 24L*3600*1000;
long convertDaysToMilliseconds(int days) { return days * MILLISECONDS_PER_DAY; } 
]]>
int 値を long に変換して絶対時間として使用している int 値 を long に変換して、{2} への絶対時間として渡しています。{1}
このコードは32ビット int 値を64ビット long 値に変換して、絶対時間値を必要とするメソッドパラメータに渡しています。 絶対時間値は、「エポック」(すなわち、1970年1月1日、00:00:00 GMT)としてわかっている標準的な基準時間からのミリ秒数です。
たとえば、次のメソッド (エポックからの秒を Date へ変換することを意図した) はひどく壊れています。

Date getDate(int seconds) { return new Date(seconds * 1000); }

乗算は32ビット演算を使用して、64ビット値に変換されます。 32ビット値は、64ビットに変換されて、絶対時間値を表すために使用されるとき、1969年12月と1970年1月の日付しか表せません。

上記のメソッドの正しい実装は以下のとおりです。

// 失敗、2037年後の日付
Date getDate(int seconds) { return new Date(seconds * 1000L); }

// より良い、すべての日付で動作する
Date getDate(long seconds) { return new Date(seconds * 1000); }
]]>
整数値を float にキャストして Math.round() に渡している 整数値を float にキャストして、Math.round() に渡しています。{1}
このコードは整数値を float 精度浮動小数点に変換してから、その結果を Math.round() に渡して引数に最も近い int/long を返します。 整数を float に変換すると小数部がない数値が得られるので、この演算は常にノーオペレーションになります。 Math.round()に渡される値を生成した演算が浮動小数点演算を使用して実行することを意図した可能性が高いです。

]]>
整数値を double にキャストして Math.ceil() に渡している 整数値を double にキャストして、Math.ceil() に渡しています。{1}
このコードは整数値 (たとえば、int や long) を倍精度浮動小数点に変換してから、その結果を Math.ceil() に渡しています。 整数を double に変換すると小数部がない数値が得られるので、この演算は常にノーオペレーションになります。 Math.ceil()に渡される値を生成した演算が倍精度浮動小数点演算を使用して実行することを意図した可能性が高いです。

]]>
整数の除算の結果を double または float にキャストしている 整数の除算の結果を double または float にキャストしています。{1}
このコードは整数の除算の結果を double または float にキャストしています。 整数で除算をすることは、ゼロに最も近い整数値まで結果を切り捨てます。 結果が double にキャストされたという事実は、この精度が維持されるべきだったことを示唆しています。 おそらく意味されたことは、除算を実行する前にオペランドの1つまたは両方を double にキャストすることでした。
以下に例を示します。

int x = 2;
int y = 5;
// Wrong: yields result 0.0
double value1 =  x / y;

// Right: yields result 0.4
double value2 =  x / (double) y;
]]>
HttpSession への非直列化可能オブジェクトの格納 非直列化可能オブジェクト {2} を HttpSession に格納しています。{1}
このコードは HttpSession に非直列化可能オブジェクトを格納していると思われます。 このセッションが不活性化されるか移行したなら、エラーを招きます。

]]>
ObjectOutput に書き込まれる非直列化可能オブジェクト 非直列化可能オブジェクト {2} が ObjectOutput に書き込まれています。{1}
このコードは ObjectOutput.writeObject に非直列化可能オブジェクトを渡していると思われます。 このオブジェクトが本当に非直列化可能なら、エラーを招きます。

]]>
書式文字列ための前の引数がない 書式文字列の引数 {2} の前の引数がありません。{1}
この書式文字列は前の書式指示子の引数が再利用されるようにするために「相対インデックス ("<")」を指定しています。 しかしながら、前の引数がありません。 たとえば、formatter.format("%<s %s", "a", "b") が実行されると MissingFormatArgumentException をスローします。

]]>
書式文字列は \n よりも %n を使用するべき 書式文字列は、\n よりも %n を使用するべきです。{1}
この書式文字列は改行文字 (\n) が含まれています。 一般的に書式文字列には %n を使用することがより望ましいです。%n は、プラットホーム特有の行セパレータを作り出します。

]]>
与えられた引数の型は書式指示子に合致しない 引数の型 {3} は、書式指示子 {4} によって扱えません。{1}
引数の1つは対応する書式指示子と互換性がありません。その結果、実行されるときに実行時例外を生成します。 たとえば、String.format("%d", "1") は、文字列 "1" が書式指示子 "%d" と互換性がないので例外を生成します。

]]>
Boolean 型でない引数を %b 書式指示子を使用してフォーマットしている Boolean 型でない引数を %b 書式指示子を使用してフォーマットしています。{1}
Boolean 型でない引数を %b 書式指示子でフォーマットしています。これは例外をスローしません。 その代わりに、非 null 値では true 、null では false を出力します。 書式文字列のこの機能は奇妙で意図したことではないかもしれません。

]]>
書式文字列を使用して役に立たない方法で配列をフォーマットしている 役に立たない方法で引数の型 {3} をフォーマットしています。{1}
書式文字列でフォーマットされている引数の1つは配列です。 [I@304282 のように配列のコンテンツを表示しないかなり役に立たない書式を使用してフォーマットされます。 フォーマットで扱う前に Arrays.asList(...) を使用して配列をラップすることを検討してください。

]]>
書式文字列への引数の数と書式指示子の数が一致していない 書式文字列は "{3}" によって呼び出されている書式文字列メソッド {2} は、書式指示子の数が {4} なのに 引数の数は {5} です。{1}
可変長引数による書式文字列メソッドが呼び出されていますが渡された引数の数と書式文字列の中の % 書式指示子の数が一致していません。 これはおそらく作成者の意図したことではありません。

]]>
printf スタイルの書式が期待されているところで MessageFormat が与えられている {2} は、prntf スタイルの書式を必要としていますが MessageFormat によって呼び出されています。
Java の printf 書式文字列と引数のリストを期待するメソッドが呼び出されています。 しかしながら、書式文字列にはどんな書式指示子 (たとえば、%s) も含まないで、メッセージフォーマットの要素 (たとえば、{0}) を含んでいます。 printf スタイルの書式文字列が必要なときに、MessageFormat の文字列を与えている可能性が高いです。 実行時に、すべての引数は無視され、書式文字列は正確にフォーマットされずに返されます。

]]>
書式文字列で実際に使われるより、多くの引数が渡されている 書式文字列 {3} によって呼び出されている書式文字列メソッド {2} は、書式指示子の数が {4} なのに 引数の数は {5} です。{1}
可変長引数による書式文字列メソッドが呼び出されていますが書式文字列で実際に使われるより多くの引数が渡されています。 これは実行時例外の原因とはなりませんが、コードはフォーマットされた文字列に含まれることを意図した情報を黙って省略しているかもしれません。

]]>
無効な書式文字列 無効な書式文字列 "{3}" です。{1}
書式文字列は構文的に無効です。この文が実行されると実行時例外が発生します。

]]>
書式文字列は足りない引数を参照している 書式文字列 "{3}" は 引数が {5} 必要なのに {6} だけしか与えられていません。{1}
書式文字列で書式指示子を満たすために十分な引数が渡されていません。この文が実行されると実行時例外が発生します。

]]>
書式指示子へ渡している引数に互換性がない 書式指示子 {4} は、対応する引数と互換性がありません。{1}
書式指示子は、対応する引数と互換性がありません。 たとえば、System.out.println("%d\n", "hello"); の %d 書式指示子は数値の引数を必要としますが数値ではなく文字列が渡されています。 この文が実行されると実行時例外が発生します。

]]>
可変長引数を期待しているメソッドにプリミティブ型の配列を渡している 可変長引数のメソッド {3} に {2} を渡しています。{1}
このコードは可変長引数をとるメソッドにプリミティブ型の配列を渡しています。 これはプリミティブ型の配列を保持するために長さが1の配列を作成してメソッドに渡します。

]]>
equals メソッドは引数の型を仮定するべきではない {0} のための equals メソッドは、引数の型が {0.givenClass} だと仮定しています。
equals(Object o) メソッドは、o の型についてどんな仮定もするべきではありません。 othis と同じ型でないなら単に false を返すべきです。

]]>
抽象コレクションへの疑わしいキャスト Collection から抽象クラス {3} への疑わしいキャストです。{1}
このコードはCollection を抽象コレクションにキャストしています (たとえば ListSetMap)。 オブジェクトがキャストする型であるということが保証されていることを確認してください。 必要とするコレクションの反復処理ができるなら Set または List にキャストする必要はありません。

]]>
プリミティブ型の配列を含んでいる不可能なキャスト プリミティブ型の配列を含んでいる不可能なキャストです。{1}
このキャストは、常にClassCastException をスローします。

]]>
不可能なキャスト {2} から {3} への不可能なキャストです。{1}
このキャストは、常に ClassCastException をスローします。 FindBugs は、instanceof チェックから型情報を調査して、メソッドからの戻り値とフィールドからロードされた値の型について、より多くの正確な情報を使用します。 したがって、宣言された変数の型にはより多くの正確な情報があるかもしれないしれません。 また、キャストが常に実行時例外をスローするのかを決定するために利用する可能性があります。

]]>
不可能なダウンキャスト {2} から {3} への不可能なダウンキャストです。{1}
このキャストは、常に ClassCastException をスローします。 解析はキャストしている値の正確な型がわかっていると信じています。 そして、サブタイプへダウンキャストしようとする試みは、ClassCastException のスローによって常に失敗します。

]]>
toArray メソッドの結果の不可能なダウンキャスト {3} への toArray メソッドの結果の不可能なダウンキャストです。{1}
このコードは以下のように、Object[] より特定の型のコレクションで toArray メソッドを呼び出す結果をキャストしています。

String[] getAsArray(Collection<String> c) {
  return (String[]) c.toArray();
}

これは通常 ClassCastException をスローして失敗します。 ほとんどすべてのコレクションの toArray メソッドは、Object[] を返します。 Collection オブジェクトは宣言された総称型コレクションの参照がないので、本当に何もできません。 コレクションから特定の型の配列を得る正しい方法は、c.toArray(new String[]); または c.toArray(new String[c.size()]); (後者はわずかにより効率的です) を使用することです。 これに対する1つの共通の知られている例外があります。 Arrays.asList(...)によって返されるリストの toArray() メソッドは共変型配列を返します。 たとえば、Arrays.asArray(new String[] { "a" }).toArray()String [] を返します。 FindBugs はそのようなケースを検出して抑止しようとしますが、見落としているかもしれません。

]]>
null とわかっている値をその型のインスタンスなのか確かめている null とわかっている値を {2} のインスタンスなのか確かめています。{1}
チェックされている値が null であることが保証されているので、instanceof は常に faluse を返します。 これは安全で、誤解や論理エラーを指摘していないことを確認してください。

]]>
A known null value is checked to see if it is an instance of a type A known null value is checked to see if it is an instance of {2} in {1}
This instanceof test will always return false, since the value being checked is guaranteed to be null. Although this is safe, make sure it isn't an indication of some misunderstanding or some other logic error.

]]>
常に false を返す instanceof {2} が {3} である可能性がないので、instanceof は常に false を返します。{1}
この instanceof は常に false を返します。これは安全で、誤解や論理エラーを指摘していないことを確認してください。

]]>
常に true を返す instanceof {2} は {3} のインスタンスなので instanceof は常にすべての非 null 値に対して true を返します。
この instanceof は常に true を返します (テストしている値が null でないかぎり)。 これは安全で、誤解や論理エラーを指摘していないことを確認してください。 本当に null なのか値をテストしたいなら、多分、instanceof ではなく null テストをしたほうが良く、より明確になります。

]]>
未チェック/未確認のキャスト {2} から {3} への未チェック/未確認のキャストです。{1}
このキャストはチェックされていません。すべての型のインスタンスをキャストする型へキャストできるわけではありません。 プログラムのロジックがこのキャストが失敗しないことを確実に確認してください。

]]>
メソッドからの戻り値の未チェック/未確認のキャスト {2} からの {3} 戻り値への未チェック/未確認のキャストです。{1}
このコードはメソッドの戻り値の未確認のキャストを実行しています。 コードは、キャストが安全であることが保証されるようにメソッドを呼び出しているかもしれませんが、FindBugs はキャストが安全であることを検証できません。 プログラムのロジックがこのキャストが失敗しないことを確実に確認してください。

]]>
具象コレクションへの疑わしいキャスト {2} から {3} への疑わしいキャストです。{1}
このコードは抽象コレクション (たとえば、Collection、List、Set) を特定の具象実装 (たとえば、ArrayList、HashSet) にキャストしています。 これは正しくないかもしれません。そして、将来の時点で他の具象実装への切り替えをとても困難にするので、脆弱なコードになるかもしれません。 そうするための特別な理由がないかぎり抽象コレクションクラスを使用してください。

]]>
正規表現のために使われている "." または "|" 正規表現で "." または "|" を使用しています。{1}
String 機能が呼び出されていて、"." または "|" が引数として正規表現を取るパラメータに渡されています。 これは意図したことですか? たとえば

  • s.replaceAll(".", "/") は、すべての文字が '/' 文字に置換された String を返す
  • s.split(".") は、常に長さが0の String 配列を返す
  • "ab|cd".replaceAll("|", "/") は、"/a/b/|/c/d/" を返す
  • "ab|cd".split("|") は、6個の要素がある配列を返す: [, a, b, |, c, d]
]]>
正規表現のための無効な構文 正規表現のための無効な構文です。{1}
このコードは正規表現の構文によると無効である正規表現を使用しています。 この文が実行されるとき PatternSyntaxException をスローします。

]]>
正規表現のために使われている File.separator File.separator が正規表現のために使われています。{1}
このコードは正規表現が必要な場所で、File.separator を使用しています。 これは File.separator がバックスラッシュである Windows プラットホームでは失敗します。 バックスラッシュは正規表現ではエスケープ文字として解釈されます。 その他の選択肢としては、File.separator の代わりに File.separatorChar=='\\' ? "\\\\" : File.separator を使用できます。

]]>
上書きされたインクリメント 上書きされたインクリメントです。{1}
このコードはインクリメント演算 (たとえば、i++) を実行してすぐに上書きしています。 たとえば、i = i++ は元の値をインクリメントした値で上書きします。

]]>
符号なし右シフトを short/byte にキャストしている 符号なし右シフトを short/byte にキャストしています。{1}
このコードは符号なしキャストの実行結果を short または byte にキャストしています。結果の上位ビットは捨てられます。 上位ビットが捨てられるので、符号付きと符号なし右シフト (シフトのサイズによって) との違いがないかもしれません。

]]>
シフト演算の正しくない構文解析の可能性がある シフト演算の正しくない構文解析の可能性があります。{1}
コードは (x << 8 + y) のような操作を行います。 これは正しいかもしれませんが、おそらく (x << 8) + y を行うことを意図していました。 しかし、シフト演算は優先順位が低いので、実際には x << (8 + y) として構文解析されます。

]]>
32ビット int の-31から31の範囲を超えた量によるシフト 32ビット int を {2} ビットでシフトしました。{1}
このコードは32ビット int の-31から31の範囲を超えた量でシフトを実行しています。 これの効果は、どのくらいシフトするのかを決めるために整数値の下位5ビット (32で割った余り) を使用することです (たとえば、40ビットでシフトすることは8ビットでシフトすることと同じで、32ビットでシフトすることは0ビットでシフトすることと同じです)。 これはおそらく期待されたことではなく、少なくとも紛らわしいです。

]]>
整数剰余の結果の整数乗算 整数剰余の結果の整数乗算。{1}
このコードは整数剰余の結果に整数定数を乗算しています。 紛らわしい演算子の優先順位がないことを確実にしてください。 たとえば、i % 60 * 1000 は、i % (60 * 1000) ではなく (i % 60) * 1000 となります。

]]>
配列で hashCode メソッドを呼び出している 配列で hashCode メソッドを呼び出しています。{1}
このコードは配列で hashCode メソッドを呼び出しています。 配列で hashCode メソッドを呼び出すことは、System.identityHashCode と同じ値を返すので、コンテンツと配列の長さを無視します。 配列 a のコンテンツによるハッシュコードを必要とするなら、java.util.Arrays.hashCode(a) を使用してください。

]]>
配列で toString メソッドを呼び出している {2.givenClass} で toString メソッドを呼び出しています。{1}
このコードは配列で toString メソッドを呼び出しています。「[C@16f0472」のようなかなり役に立たない結果を生成します。 配列のコンテンツを与え、読める文字列に変換するために Arrays.toString() を使用することを検討してください。
『Programming Puzzlers』の第3章、パズル12を参照してください。

]]>
名前のない配列で toString メソッドを呼び出している 名前のない配列で toString メソッドを呼び出しています。{1}
このコードは無名の配列で toString メソッドを呼び出しています。「[C@16f0472」のようなかなり役に立たない結果を生成します。 配列のコンテンツを与え、読める文字列に変換するために Arrays.toString() を使用することを検討してください。
『Programming Puzzlers』の第3章、パズル12を参照してください。

]]>
平均の計算はオーバーフローする可能性がある 平均の計算は、オーバーフローする可能性があります。{1}
このコードは除算か符号付き右シフトを使用して2つの整数の平均を計算して、結果を配列の添字として使用しています。 平均値が非常に大きいならオーバーフローする可能性があります (結果として負の平均の計算になる)。 結果が負でないことを意図していたなら、その代わりに符号なし右シフトを使用できます。 つまり、(low+high)/2 ではなく (low+high) >>> 1 を使用してください。

このバグは、二分探索とマージソートの多くの以前の実装で存在します。 Martin Buchholz が JDK ライブラリのバグを発見して修正しています。 Joshua Bloch が バグパターンとして公表しました

]]>
負数で機能しない奇数チェック 負数で機能しない奇数チェックです。{1}
このコードは x % 2 == 1 を使用して値が負数なのか確かめていますが、負数 (たとえば、(-5) % 2 == -1) なので機能しません。 奇数チェックを意図しているなら、x & 1 == 1 または x % 2 != 0 を使用することを検討してください。

]]>
ハードコードされた絶対パス名への参照がある ハードコードされた絶対パス名への参照があります。{1}
このコードはハードコードされた絶対パス名を使用して File オブジェクトを構築しています (たとえば new File("/home/dannyc/workspace/j2ee/src/share/com/sun/enterprise/deployment");)。

]]>
月のための間違った定数値 間違った月の値 {2} を {3} に渡しています。{1}
このコードはメソッドに0から11の範囲外の月定数値を渡しています。

]]>
substring(0) の呼び出しは元の値を返す {1} は、元の値を返す substring(0) を呼び出しています。
このコードは文字列で substring(0) を呼び出していますが、元の値を返します。

]]>
hasNext メソッドで next メソッドを呼び出している {1} は、{2.givenClass} を呼び出しています。
hasNext メソッドは、next メソッドを呼び出しています。 hasNext メソッドは、イテレータの状態を変更することになっていないので、ほぼ確実に間違っています。 next メソッドがイテレータの状態を変更することになっています。

]]>
ロックを保持して Thread.sleep() を呼び出しているメソッド {1} は、ロックを保持して Thread.sleep() を呼び出しています。
このメソッドは、ロックを保持して、Thread.sleep() を呼び出しています。 他のスレッドがロックを獲得するために待機しているかもしれないので、ひどい性能とスケーラビリティ、またはデッドロックの原因になるかもしれません。 ロックで wait メソッドを呼び出すことはかなり良い考えで、ロックを解除して他のスレッドが実行するのを許可します。

]]>
2つの分岐のために同じコードを使用しているメソッド {1} は、2つの分岐のために同じコードを使用しています。
このメソッドは、条件分岐の2つの分岐を実装するために同じコードを使用しています。これがコーディングミスではないことを確認してください。

]]>
switch 文の2つの case のために同じコードを使用しているメソッド {1} は、switch 文の2つの case のために同じコードを使用しています。
このメソッドは、switch 文の2つの case を実装するために同じコードを使用しています。 複製コードの case かもしれないし、コーディングミスかもしれません。

]]>
所有クラスの private メンバー変数にアクセスしているメソッド {1} は、所有クラスの private メンバー変数にアクセスしています。
この内部クラスのメソッドは、所有クラスの private メンバー変数への読み書きか、所有クラスの private メソッドを呼び出しています。 コンパイラはこの private メンバーにアクセスするための特別なメソッドを生成しなければなりないので、効率を悪化させる原因になります。 メンバー変数またはメソッドの保護を緩和することは、コンパイラが正常なアクセスとして扱うのを許可します。

]]>
XMLインタフェースの特定の実装のインスタンスを作成しているメソッド {1} は、XMLインタフェースの特定の実装のインスタンスを作成しています。
このメソッドは、XMLインタフェースの特定の実装のインスタンスを作成しています。 提供されたファクトリクラスを使用してオブジェクトを作成して実行時に実装を変更できるようにすることが望ましいです。
詳細は、以下を参照してください。

  • javax.xml.parsers.DocumentBuilderFactory
  • javax.xml.parsers.SAXParserFactory
  • javax.xml.transform.TransformerFactory
  • org.w3c.dom.Document.createXXXX
]]>
親クラスのメソッドに過剰に委譲しているメソッド {1} は、親クラスのメソッドに過剰に委譲しています。
この派生メソッドは、単に受け取られる正確なパラメータを渡している同じスーパークラスのメソッドを呼び出すだけです。 このメソッドは、付加価値が与えられないので除去できます。

]]>
実装されたインタフェースで既に定義された抽象メソッド 抽象メソッド {1} は、実装されたインタフェースで既に定義されています。
この抽象メソッドは、この抽象クラスによって実装されるインタフェースで既に定義されています。 このメソッドは、付加価値が与えられないので除去できます。

]]>
final なクラスが protected フィールドを宣言している クラス {0} は、final なのに protected フィールド {1} が宣言されています。
このクラスは、final と宣言されていますが、フィールドは protected と宣言されています。 クラスは fainal なので派生できません。、protected の使用は紛らわしいです。 フィールドのためのアクセス修飾子は、フィールドの真の用途を表すため、 private か public に変更するべきです。

]]>
論理式で boolean リテラル値を代入しているメソッド {1} は、論理式で boolean リテラル値を代入しています。
このメソッドは、if または while の式の中の boolean 変数に boolean リテラル値 (true または false) を代入しています。 おそらく、これは = による代入ではなく、== を使用して論理比較をすることになっていました。

]]>
解決できないクラス、メソッドへの参照 {0} による {1} への解決できない参照。
このクラスは、解析されているライブラリに対して解決されないクラスまたはメソッドを参照しています。

]]>
検査されない型への総称呼び出し 型 {3.givenClass} が期待されているところに与えられた型 Object の検査されない引数。{1}
総称型パラメータからの特定の型が予想される Object 型をコンパイルするとき、総称型コレクションメソッドへの呼び出しは引数を渡します。 したがって、標準の Java 型システムも静的解析もパラメータとして渡されているオブジェクトが適切な型かどうかに関する有用な情報を提供できません。

]]>
型パラメータとメソッド引数に関係がない {2.givenClass} は、期待された引数の型 {3.givenClass} と互換性がありません。{1}
総称型コレクションメソッドへの呼び出しにコレクションのパラメータとは互換性のないクラスの引数があります (すなわち、引数の型は総称型引数に対応するスーパタイプでもサブタイプでもありません)。 したがって、コレクションにはここで使用されたメソッド引数と等価であるどんなオブジェクトも含まれていません。 多分間違った値がメソッドに渡されています。 一般的に2つの無関係なクラスのインスタンスは等価ではありません。 たとえば、FooBar クラスがサブタイプによって関係がないなら、Foo のインスタンスは Bar のインスタンスと等価のはずがありません。 その他の問題で対称的ではない equals メソッドになる可能性が高いです。 たとえば、FooString と等価であるように Foo クラスを定義するなら、StringString だけと等価であるので、equals メソッドは対称的ではありません。

まれに、非対称 equals メソッドを定義して、まだ、何とかそれらのコードを機能させています。 APIのどれも文書化していないか、保証もしていないが、Collection<String>Foo があるかどうか調べたいなら、 引数の equals メソッド (たとえば、Fooクラスの equals メソッド) を使用して等価性をチェックします。

]]>
コレクションは自分自身を含めるべきではない コレクションは、{2.givenClass} への呼び出しで自分自身を含めるべきはない。
この総称型コレクションメソッドへの呼び出しはコレクションに自分自身が含まれている場合 (たとえば、s.contains(s) が true) にだけ意味があります。 これが本当だとは思えないし、もし本当なら問題の原因になります (たとえば、無限再帰になっているハッシュコードの計算)。 間違ったパラメータが渡されている可能性が高いです。

]]>
コレクションへの無意味な呼び出し コレクション c に対して c.{2.name}(c) を呼び出すことは意味がありません。
この呼び出しは意味がありません。 どんなコレクション cc.containsAll(c) を呼び出すことは常に true であるべきです。 そして、c.retainAll(c) は効果があるはずがありません。

]]>
繰り返しでエントリオブジェクトを再利用しない {0} は Iterator と Map.Entry の両方があります。
このクラスは、Iterator と Map.Entry で基底 Map のビューを返すことを許可された両方の entrySet メソッドがあります。 この巧妙なアイデアは、Map 実装で使用されましたが、厄介なコーディング間違いの可能性を取り込みました。 Map m が entrySet のためのそのような反復子を返すならば、c.addAll(m.entrySet()) はひどく間違っているでしょう。 OpenJDK 1.7 の すべての Map 実装はこれを回避するために書き直されました。

]]>
エントリセットの要素を加えることは、Entry オブジェクトの再利用のために失敗するかもしれない エントリセットの要素を加えることは、{2.simpleClass} の再利用のために失敗するかもしれません。{1} の Entry オブジェクト
entrySet メソッドは、一つの Entry オブジェクトを再利用し、反復中に返される基底 Map のビューを返すことが許可されています。 Java 1.6 の時点で、IdentityHashMap と EnumMap の両方がそうしました。 そのような Map を通して繰り返すとき、エントリ値は次の繰り返しへ進むまでが有効です。 たとえば、addAll メソッドにそのような entrySet を渡そうと試みるのは、ひどく間違っているでしょう。

]]>
コレクションを消去するために removeAll メソッドを使用しない コレクションを消去するために removeAll メソッドを使用しています。{1}
コレクション c からすべての要素を除去したいなら、c.removeAll(c) ではなく c.clear を使用してください。 コレクションを消去するために c.removeAll(c) を呼び出すことは、それほど明確ではなく、タイプミスからの誤りに影響されやすく、効率的ではなく、いくつかのコレクションでは、ConcurrentModificationException をスローするかもしれません。

]]>
static Calendar フィールド {1} は、java.util.Calendar 型の static フィールドです。それはスレッドセーフではありません。
たとえ JavaDoc にそれに関する手がかりがないとしても、Calendar はマルチスレッドでの使用は本質的に安全でありません。 正しい同期化をしないでスレッド境界の向こうで1つのインスタンスを共有することは、アプリケーションの誤動作になります。 JDK 5.0に比べて JDK 1.4 のほうが問題が表面化するように思われ、おそらく sun.util.calendar.BaseCalendar.getCalendarDateFromFixedDate() の ArrayIndexOutOfBoundsExceptions や IndexOutOfBoundsExceptions がランダムに発生します。 直列化問題も経験するかもしれません。インスタンスフィールドを使用することを推奨します。
詳細については、Sun Bug #6231579Sun Bug #6178997 を参照してください。

]]>
static Calendar の呼び出し static な java.util.Calendar のメソッドを呼び出しています。{1}
たとえ JavaDoc にそれに関する手がかりがないとしても、Calendar はマルチスレッドでの使用は本質的に安全ではありません。 ディテクタは、static フィールドから得られた Calendar のインスタンスの呼び出しを発見しました。 これは疑わしく見えます。 詳細については、Sun Bug #6231579Sun Bug #6178997 を参照してください。

]]>
static DateFormat フィールド {1} は、java.text.DateFormat 型の static フィールドです。それはスレッドセーフではありません。
JavaDoc に書かれているように DateFormat はマルチスレッドでの使用は本質的に安全ではありません。 正しい同期化をしないでスレッド境界の向こうで1つのインスタンスを共有することは、アプリケーションの誤動作になります。 JDK 5.0に比べて JDK 1.4 のほうが問題が表面化するように思われ、おそらく sun.util.calendar.BaseCalendar.getCalendarDateFromFixedDate() の ArrayIndexOutOfBoundsExceptions や IndexOutOfBoundsExceptions がランダムに発生します。 直列化問題も経験するかもしれません。インスタンスフィールドを使用することを推奨します。
詳細については、Sun Bug #6231579Sun Bug #6178997 を参照してください。

]]>
static DateFormat の呼び出し static な java.text.DateFormat のメソッドを呼び出しています。{1}
JavaDoc に書かれているように DateFormat はマルチスレッドでの使用は本質的に安全ではありません。 ディテクタは、static フィールドから得られた DateFormat のインスタンスの呼び出しを発見しました。 これは疑わしく見えます。 詳細については、Sun Bug #6231579Sun Bug #6178997 を参照してください。

]]>
互換性のない型修飾子による比較値 型修飾子 {2.simpleName} でアノテートされた値がその修飾子がない値と等価性のために比較されています。
型修飾子アノテーションを指定した値がその修飾子のない値と比較しています。

より正確に、when=ALWAYS を指定した型修飾子でアノテートされた値が同じ型修飾子で when=NEVER を指定する値と比較しています。

たとえば、@NonNegative は型修飾子アノテーション @Negative(when=When.NEVER) の略称とします。 以下のコードは、return 文が @NonNegative 値を要求するが、@Negative としてマークされている値を受け取るのでこの警告を生成します。

public boolean example(@Negative Integer value1, @NonNegative Integer value2) {
    return value1.equals(value2);
}
]]>
型修飾子でアノテーションされた値がその修飾子を付けてはならない値を必要とする場所で使われている 型修飾子 {2} でアノテートされた値がその修飾子を付けてはならない値を必要とする場所で使われています。
型修飾子でアノテートされた値がその修飾子を付けてはならない値を必要とする場所で使われています。

より正確に、when=ALWAYS を指定した型修飾子でアノテートされた値が到達することが保証されているか同じ型修飾子で when=NEVER を指定する場所で使用しています。

たとえば、@NonNegative は型修飾子アノテーション @Negative(when=When.NEVER) の略称とします。 以下のコードは、return 文が @NonNegative 値を要求するが @Negative としてマークされている値を受け取るのでこの警告を生成します。

public @NonNegative Integer example(@Negative Integer value) {
    return value;
}
]]>
型修飾子がない値が修飾子を必要とする場所で使われている {2.simpleName} アノテーションを必要とする場所で型修飾子がない値が使われています。
値が型修飾子アノテーションを必要とする方法で使われています。型修飾子は厳密なので、ツールは適切なアノテーションを指定していない値を拒絶します。

厳密なアノテーションを指定しているので値を型変換します。戻り値が厳密なアノテーションでアノテートされる同一性機能を定義してください。 これは厳密な型修飾子アノテーションで非アノテート値を値に変える唯一の方法です。

]]>
型修飾子でアノテートされていない値がその修飾子が付けられた値を必要とする場所で使われている 型修飾子 {2.simpleName} でアノテートされていない値がその修飾子が付けられた値を必要とする場所で使われています。
型修飾子でアノテートされていない値がその修飾子が付けられた値を必要とする場所で使われています。

より正確に、when=NEVER を指定した型修飾子でアノテートされた値が同じ型修飾子で when=ALWAYS を指定する場所で使用しています。

]]>
型修飾子を付けていないかもしれない値がその型修飾子を必要とする方法で常に使われている {2.simpleName} アノテーションを付けていないかもしれない値がその型修飾子を必要とする方法で常に使われています。
型修飾子によって示された値のインスタンスではない可能性としてアノテートされた値です。 値は、その型修飾子によって示された値を必要とする方法で使われることが保証されています。

]]>
型修飾子を付けているかもしれない値がその型修飾子を禁止する方法で常に使われている {2.simpleName} アノテーションを付けているかもしれない値がその型修飾子を禁止する方法で常に使われています。
型修飾子によって示された値のインスタンスである可能性としてアノテートされた値です。 値は、その型修飾子によって示された値を禁止する方法で使われることが保証されています。

]]>
値は型修飾子を必要としないが、不明としてマークされている 値は、{2.simpleName} を必要としませんが、明示的に {2.simpleName} に関して不明としてアノテーションされています。
値は、型修飾子によって示された値でないことを必要とする方法で使われています。 しかし、値はどこでその型修飾子がいるのか禁止されていのるかわからないと述べている明示的なアノテーションがあります。 使い方かアノテーションのどちらかが間違っています。

]]>
値は型修飾子を必要としているが、不明としてマークされている 値は、常に {2.simpleName} を必要としていますが、明示的に {2.simpleName} に関して不明としてアノテーションされています。
値は、常に型修飾子によって示された値であることを必要とする方法で使われています。 しかし、値はどこでその型修飾子が必要なのかわからないと述べている明示的なアノテーションがあります。 使い方かアノテーションのどちらかが間違っています。

]]>
オブジェクト出力ストリームへの追加は失敗に終わる オブジェクト出力ストリームへの追加は失敗に終わります。{1}
このコードはファイルを追加モードで開いて、オブジェクト出力ストリームの中で結果をラップしています。 これはファイルに格納された既存のオブジェクト出力ストリームに追加できないでしょう。 オブジェクト出力ストリームに追加したいなら、オブジェクト出力ストリームを開いておく必要があります。

追加モードでファイルを開き、オブジェクト出力ストリームで書き込むことができる唯一の状況は、 ファイルを読み出すときにランダムアクセスモードで開き、追加を開始するところまでバイトオフセットをシークすると計画した場合です。

]]>
クラスリテラルではなく getClass で同期化している クラスリテラルではなく getClass で同期化しています。{1}
このインスタンスメソッドは、this.getClass() で同期化しています。 このクラスがサブクラス化されるなら、サブクラスはおそらく意図したことではないサブクラスのためにクラスオブジェクトで同期化します。 たとえば、java.awt.Label の以下のコードを検討してください。

private static final String base = "label";
private static int nameCounter = 0;

String constructComponentName() {
    synchronized (getClass()) {
        return base + nameCounter++;
    }
}

Label のサブクラスは同じサブクラスで同期化しません。データレースを生じさせます。 代わりに、このコードは Label.class で同期化するべきです。

private static final String base = "label";
private static int nameCounter = 0;

String constructComponentName() {
    synchronized (Label.class) {
        return base + nameCounter++;
    }
}

Jason Mehrens によって寄贈されたバグパターン

]]>
ストリームやリソースのクリーンアップに失敗するかもしれないメソッド {1} は、{2} のクリーンアップに失敗するかもしれません。
このメソッドは、ストリーム、データベースオブジェクト、またはクリーンアップ操作を明示的に必要としている他のリソースのクリーンアップ (クローズする、片付ける) に失敗するかもしれません。

一般的にメソッドがストリープや他のリソースを開いたなら、メソッドはストリームやリソースがメソッドが戻る前にクリーンアップされることを確認するために try/finally ブロックを使用するべきです。

このバグパターンは、OS_OPEN_STREAM と ODR_OPEN_DATABASE_RESOURCE と基本的に同じですが異なる (そして、うまくいけばより良い) 静的解析技術に基づいています。 私たちは、このバグパターンの有効性についてのフィードバックを得ることに関心があります。 どちらかの方法でフィードバックを送ってください。

特に、このバグパターンの誤検出抑制探索法は詳細にわたって調整されていないので、誤検出についてのレポートは我々の助けになります。

解析技術の説明は、Weimer と Necula による Finding and Preventing Run-Time Error Handling Mistakes を参照してください。

]]>
チェック例外でストリームやリソースのクリーンアップに失敗するかもしれないメソッド {1} は、チェック例外で {2} のクリーンアップに失敗するかもしれません。
このメソッドは、ストリーム、データベースオブジェクト、またはクリーンアップ操作を明示的必要としている他のリソースのクリーンアップ (クローズする、片付ける) に失敗するかもしれません。

一般的にメソッドがストリープや他のリソースを開いたなら、メソッドはストリームやリソースがメソッドが戻る前にクリーンアップされることを確認するために try/finally ブロックを使用するべきです。

このバグパターンは、OS_OPEN_STREAM と ODR_OPEN_DATABASE_RESOURCE と基本的に同じですが異なる (そして、うまくいけばより良い) 静的解析技術に基づいています。 私たちは、このバグパターンの有効性についてのフィードバックを得ることに関心があります。 どちらかの方法でフィードバックを送ってください。

特に、このバグパターンの誤検出抑制探索法は詳細にわたって調整されていないので、誤検出についてのレポートは我々の助けになります。

解析技術の説明は、Weimer と Necula による Finding and Preventing Run-Time Error Handling Mistakes を参照してください。

]]>
FindBugs からの予期しない/望ましくない警告 予期しない/望ましくない {2} FindBugs 警告。{1}
FindBugs は、@NoWarning でアノテートされたことにより予期しない/望ましくない警告を生成しました。

]]>
失われた FindBugs からの予期した/望ましい警告 失われた予期した/望ましい {2} FindBugs 警告。{1}
FindBugs は、@ExpectedWarning でアノテートされたことにより予期した/望ましい警告が生成されませんでした。

]]>
putIfAbsent の戻り値は無視されて putIfAbsent に渡した値は再利用された putIfAbsent の戻り値は無視されたが、{4} は再利用されました。{1}
putIfAbsent メソッドは、1つの値が与えられたキー (非存在が成功するかどうかの第一の値) と関連することを確認するために使われます。 戻り値を無視して中で渡される値への参照を保持するなら、マップのキーと関連する1つではない値を保持する危険性を冒します。 どれを使用するかが重要であり、マップに格納できないものを使うとプログラムは誤った振る舞いをします。

]]>
ロガーの変更は OpenJDK の弱参照が原因で潜在的に失われる ロガーの変更は失われる可能性があります。{1}
OpenJDK は、潜在的非互換性を取り入れました。特に、java.util.logging.Logger は振る舞いが変更されています。 強参照を使用する代わりに弱参照を内部的に使用しています。 それは理にかなった変更ですが、残念ながらいくつかのコードは古い振る舞いに依存しています。 ロガーの構成を変更するとき、ロガーへの参照を捨てます。 つまり、ガベージコレクタはそのメモリを回収できます。それは、ロガーの構成が失われることを意味します。
たとえば、以下を検討してください。

public static void initLogging() throws Exception {
    Logger logger = Logger.getLogger("edu.umd.cs");
    logger.addHandler(new FileHandler()); // ロガーの構成の変更
    logger.setUseParentHandlers(false); // 別のロガーの構成の変更
}

ロガーの参照は、メソッドの終わり (メソッドは脱出しません) で失われるので、 initLogging の呼び出しの後でガベージコレクションの循環があるなら、ロガー構成は失われます (なぜなら Logger は弱参照を保持するだけなので)。

public static void main(String[] args) throws Exception {
    initLogging(); // ファイルハンドラーをロガーに追加する
    System.gc(); // ロガーの構成が失われる
    Logger.getLogger("edu.umd.cs").info("Some message"); // 期待したようにファイルに記録されません
}

Ulf Ochsenfahrt と Eric Fellheimer

]]>
並行抽象の呼び出しシーケンスはアトミックではないかもしれない {2} の呼び出しシーケンスは、アトミックではないかもしれません。{1}
このコードには並行抽象化 (たとえば、並行ハッシュマップ) の呼び出しシーケンスがあります。 これらの呼び出しは原子的に実行されません。

]]>
デフォルトエンコーディングへの依存 デフォルトエンコーディングへの依存を発見しました。{1}: {2}
byte から String (または String から byte) への変換で、デフォルトプラットホームエンコーディングが適切だと仮定するメソッドの呼び出しを発見しました。 これはアプリケーションの振る舞いがプラットホーム間で異なる原因となります。代替 API を使用して、文字セット名または Charset オブジェクトを明示的に指定して下さい。

]]>
メソッドはパラメータに nullness アノテーションを強化している メソッド {1} は、祖先メソッドの要件を緩和する nullness アノテーションをオーバーライドしています。
メソッドは、オーバーライドするメソッドの契約を常に実装するべきです。 したがって、メソッドが @Nullable としてマークされるパラメーターを取るならば、サブクラスでパラメーターを @Nonnull にしてメソッドをオーバーライドするべきでありません。 そうするとメソッドが null パラメータを処理すべき契約を破ります。

]]>
メソッドはパラメータに nullness アノテーションを強化している メソッド {1} は、互換性がない方法で nullness アノテーションのパラメータ {2} をオーバーライドしています。
メソッドは、オーバーライドするメソッドの契約を常に実装するべきです。 したがって、メソッドが @Nullable としてマークされるパラメーターを取るならば、サブクラスでパラメーターを @Nonnull にしてメソッドをオーバーライドするべきでありません。 そうするとメソッドが null パラメータを処理すべき契約を破ります。

]]>
メソッドは戻り値の nullness アノテーションを緩和している メソッド {1} は、互換性がない方法で戻り値の nullness アノテーションをオーバーライドしています。
メソッドは、オーバーライドするメソッドの契約を常に実装するべきです。 したがって、メソッドが @Nonnull 値を返すようにアノテートしているならば、サブクラスでメソッドが @Nullable または @CheckForNull 値を返すようにアノテートしてメソッドをオーバーライドするべきでありません。 そうするとメソッドが null を返すべできではない契約を破ります。

]]>
書式文字列の問題 スキップした解析 無限ループ volatile の使用 安全ではない継承 浮動小数点精度の使用 プロトタイプと未完成のバグパターンのテスト 疑わしい IllegalMonitorStateException のキャッチ クローン可能イディオムの間違った実装 共変配列代入 原子性違反の可能性 ファイナライザの間違った使用 == や != を使用している文字列の等価性チェック 更新されるフィールドで同期化 (可変ロック) 同期化していない get メソッド、同期化している set メソッド 入出力の問題 初期化の循環 疑わしいスタティックイニシャライザ− 可変サーブレットフィールド 一貫性のない同期化 equals() の実装に関する問題 compareTo() の実装に関する問題 等価なオブジェクトは、等価なハッシュコードを持たなければならない APIの誤用 疑わしいメソッドの使用 疑わしいプリミティブ値のボクシング コンストラクタで未初期化フィールドの読み出し InputStream.read() の戻り値の無視 裸の notify() 無条件の wait() スピンロック ダブルチェックパターン ループの中にない wait() notifyAll() ではなく notify() を使用している 捨てられたか無視された例外 run() の呼び出し イテレータの間違った定義 Version ID のない直列化可能クラス 直列化可能クラスの間違った定義 writeObject() は同期化しているが、その他のメソッドは同期化していない readObject() を同期化している Thread.start() を呼び出すコンストラクタ 可変 static フィールド 可変列挙型フィールド 内部表現を暴露するかもしれない配列を返すメソッド 紛らわしいメソッド名 読み出されないフィールドは static にすべき 未使用フィールド 読み出されないフィールド 書き込まれないフィールド static にできる内部クラス 2つのロックを保持する wait() 範囲チェック メソッドからの戻り値の間違った使用 Logger の問題 あいまいな呼び出し 巨大な文字列定数 HRS 脆弱性 パストラバーサル XSS 脆弱性 null値 の利用 偽のランダム警告 条件テストの繰り返し すべての経路でクローズされないストリーム 結果がないことを示すために null より長さ0の配列を選ぶ 役に立たない制御フロー null への冗長な比較 すべての経路で解除されないロック 疑わしい参照等価性の使用 互換性のない型による等価性比較 ミスマッチの wait() か notify() 役に立たない自己演算 疑わしい整数式 疑わしいビット演算式 非同期化な遅延初期化 java.util.concurrent オブジェクトの同期化 決して呼び出されない private メソッド 無名クラスの呼び出しできないメソッド 可変オブジェクトへの参照の格納 疑わしい非短絡論理演算子の使用 すべての経路でクローズされないデータベースリソース ループの中で + 演算子を使用した文字列連結 ループの外に移動できる非効率なコード 非効率な String.indexOf(String) または String.lastIndexOf(String) の使用 効率が悪い collection.toArray(new Foo[0]) の使用 Swing コーディング規約 誤って実装された JUnit TestCase 間違ってオーバーライドされた Adapter switch 文のフォールスルー 不必要な instanceof 間違ったアプレットのコンストラクタ Object.equals() を使用する 疑わしい Thread.interrupted() ローカル変数への無効な代入 無視されたパラメータ 隠されたフィールド 効率が悪い Map イテレータ インスタンス化された static クラス RuntimeException の捕捉 浮動小数点の等価性テスト 定数に関する不必要な Math 役に立たないコード 既知の定数の雑な値 循環依存関係 冗長なインタフェース マルチスレッドでのインスタンスアクセス 公開セマフォ 間違ったシフト 整数値からのキャスト 正規表現 潜在的 SQL 問題 間違ったオブジェクトでロックしている可能性がある 空の synchronized ブロック 疑わしい for ループ 可変長引数の問題 オブジェクト参照の間違ったキャスト 疑わしい整数計算 static フィールドの誤用 net.jcip アノテーションの違反 役に立たない/無益な文字列生成 疑わしいメソッド呼び出し Joshua Bloch と Neal Gafter による『Java Puzzlers』に影響を受けた警告 ロックを保持する sleep Java EE のエラー 複製された分岐 効率が悪いメンバーアクセス XML ファクトリの迂回 役に立たないサブクラスメソッド 紛らわしい継承 疑わしい Boolean 代入 バージョン互換性の問題 doPrivileged の使用 疑わしい総称型コレクションメソッドの呼び出し Calendar、DateFormat の static 使用 型修飾子アノテーションの一貫性のない使用 ストリームまたはリソースをクリーンアップする責務が満たされていない FindBugs はメソッドで期待された警告を出しませんでした 共有オブジェクトを意図的でなくロックすることによる潜在的デッドロック