61

Java 定数文字列を 1 つの場所に配置し、プロジェクト全体 (多くのクラス) で使用したいと考えています。

これを達成するための推奨される方法は何ですか?

4

10 に答える 10

55
public static final String CONSTANT_STRING="CONSTANT_STRING";

定数は次のとおりです。

  1. public - どこからでもアクセスできるようにする
  2. static - インスタンスを作成する必要はありません
  3. final - その定数は変更できないため
  4. Java 命名規則に従って、読みやすく、Java ドキュメントで目立つように、大文字にする必要があります。

定数を保持するためだけにインターフェイスが使用される場合もありますが、インターフェイスは型の動作を定義することになっているため、これは悪い習慣と見なされます。

より良いアプローチは、それがより意味のあるクラスに保持することです。

例えば

JFrameEXIT_ON_CLOSEサブクラスがそれにアクセスできるすべてのクラスに定数があり、すべてのコンポーネントに閉じるオプションがあるわけではないため、保持することも保持しないJFrameことも理にかなっています。JFrameJComponent

于 2012-06-05T11:03:18.000 に答える
26

@mprabhat が前に回答したように、定数は、、、、publicおよびstatic大文字finalで入力する必要があります。

それらをクラスにグループ化すると、次のことができます。

  1. あなたが持っているすべての定数を知る必要はありません。多くの IDE (Eclipse など) は、クラスが持つすべてのフィールドのリストを表示します。したがって、押すだけCTRL+SPACEで、使用できる定数の手がかりが得られます。

  2. コンパイル時にタイプセーフにする。sを使用した場合String、 , のスペル"DATABASE_EXCEPTION"を間違える可能性があり"DATABSE_EXSCEPTION"、実行中にのみ気付く可能性があります (運が良く、まったく気付かなかった場合)。オートコンプリートを利用することもできます。

  3. 実行中にメモリを節約するのに役立ちます。定数の 1 つのインスタンスに必要なメモリは 1 つだけです。IE: (実際の例)Stringコード内の異なるクラスで "DATABASE_EXCEPTION" が 1000 回ある場合、それぞれがメモリ内の異なるインスタンスになります。

その他の考慮事項:

  1. javadoc コメントを追加して、定数を使用するプログラマーが定数に関するより多くのセマンティック情報を取得できるようにします。を押すとツールチップとして表示されますCTRL+SPACE。いいえ:

    /** Indicates an exception during data retrieving, not during connection. */
    public static final String DATABASE_EXCEPTION = "DATABASE_EXCEPTION";
    /** Indicates an exception during the connection to a database. */
    public static final String DATABASE_CONNECTION_EXCEPTION =" DATABASE_CONNECTION_EXCEPTION";
    
  2. 定数の識別子にセマンティックを追加します。定数があり、場合によってはyes"Y"を意味し、他の場合はyearを意味する場合は、2 つの異なる定数の使用を検討してください。

    public static final String Y = "Y"; // Bad
    public static final String YEAR = "Y";
    public static final String YES = "Y"; 
    

    将来、定数の値を変更する場合に役立ちます。

    /** Year symbol, used for date formatters. */
    public static final String YEAR = "A"; // Year is Año, in Spanish.
    public static final String YES = "S"; // Yes is Sí, in Spanish.
    
  3. 実行時まで定数の値がわからない場合があります。IE: 設定ファイルから読み取ることができます。

    public class Constants
    {
      /** Message to be shown to the user if there's any SQL query problem. */
      public static final String DATABASE_EXCEPTION_MESSAGE; // Made with the 2 following ones.
      public static final String DATABASE_EXCEPTION = "DATABASE_EXCEPTION";
      public static final String MESSAGE = "MESSAGE";
    
      static {
        DATABASE_EXCEPTION_MESSAGE = DATABASE_EXCEPTION + MESSAGE; // It will be executed only once, during the class's [first] instantiation.
      }
    

    }

  4. 定数クラスが大きすぎる場合、または将来大きくなりすぎると思われる場合は、異なる意味 (セマンティック) のために異なるクラスに分割できます: ConstantDBConstantNetworkなど。

欠点:

  1. チームのすべてのメンバーは、同じクラスを使用し、定数に対して同じ命名法を使用する必要があります。大規模なプロジェクトでは、2 つの定義を見つけても不思議ではありません。

    public static final String DATABASE_EXCEPTION = "DATABASE_EXCEPTION";
    public static final String EXCEPTION_DATABASE = "DATABASE_EXCEPTION"; 
    

    数百行または異なる定数クラスで区切られています。さらに悪いことに:

    /** Indicates an exception during data retrieving, not during connection. */
    public static final String DATABASE_EXCEPTION = "DATABASE_EXCEPTION";
    /** Indicates an exception during data retrieving, not during connection. */
    public static final String EXCEPTION_DATABASE = "EXCEPTION_DATABASE"; 
    

    同じ意味を持つ (同じ目的で使用される) 異なる値の異なる識別子。

  2. 可読性が低下する可能性があります。同じことをするためにもっと書く必要があります:

    if ("Y".equals(getOptionSelected()) {
    

    if (ConstantsWebForm.YES.equals(getOptionSeleted()) {
    
  3. クラス内で定数をどのように順序付ける必要がありますか? アルファベット順?関連するすべての定数を一緒に?それらが作成された/必要な順序で?注文が正しいことについて誰が責任を負うべきですか?定数の (十分に大きな) 並べ替えは、バージョン管理システムでは混乱と見なされます。

うーん、思ったより時間がかかりました。ヘルプ/批評家は大歓迎です。

于 2012-09-06T11:54:46.640 に答える
19

すべての定数を格納する定数のクラスを作成する必要があります。

ProjectNameConstants.java など

クラス名を介してアクセスできるため、すべての定数文字列 static が含まれています。

例えば

classname :  MyAppConstants.java

public static final String MY_CONST="my const string val";

次のようにアクセスできます

MyAppConstants.MY_CONST
于 2012-06-05T11:02:54.157 に答える
3

Constantsメイン パッケージ (つまり com.yourcompany) のベースで呼び出されるクラスを作成し、そこにすべての定数を含めます。また、コンストラクターをプライベートにして、このクラスからオブジェクトが作成されないようにします。

public class Constants {

    private Constants() {
        // No need to create Constants objects
    }

    public static final String CONSTANT_ONE = "VALUE_CONSTANT_ONE";
    public static final String CONSTANT_TWO = "VALUE_CONSTANT_TWO";
}
于 2012-06-05T11:16:48.027 に答える
3
public class SomeClass {
    public static final String MY_CONST = "Some Value";
}

純粋な定数クラスであることが想定されている場合は、コンストラクターもプライベートにします。

public class Constants {
    public static final String CONST_1 = "Value 1";
    public static final int CONST_2 = 754;

    private Constants() {
    }
}

その場合、このクラスをインスタンス化することはできません。

于 2012-06-05T11:04:20.380 に答える
1

あなたが探している正しい答えは

import static com.package.YourConstantsClass.*;
于 2018-05-29T02:50:01.150 に答える
0

パブリックclassを作成し、定数文字列ごとに次のようなフィールドを作成します

public static final String variableName = "string value";

于 2012-06-05T11:03:56.177 に答える