静的変数、定数、メソッド
これまでに作成した変数とメソッドは、インスタンスメソッドとインスタンス変数です。つまり、modelNumber 変数と numberInStock 変数を使用するには、最初にクラスのインスタンスを作成する必要があります。個々のインスタンスには、インスタンス変数の独自のコピーがあり、インスタンスメソッドはこれらの変数にアクセスできます。場合によっては、メンバー変数の値をすべてのインスタンスから使用できるようにする必要があります。たとえば、在庫のしきい値変数の値が Fridge クラスのすべてのインスタンスと共有されていて、あるインスタンスが行った更新を他のすべてのインスタンスから参照できるようにする場合などです。この場合、静的変数を作成する必要があります。静的変数は、インスタンスではなくクラスに関連付けられ、クラスをインスタンス化せずにアクセスできます。
インスタンスではなく、クラスに関連付けられた静的メソッドを定義することもできます。通常、インスタンスの状態に依存しないユーティリティメソッドが静的にするのに適しています。
-
次の静的変数を追加して Fridge クラスを変更します。
-
開発者コンソールで次のコードを実行します。
5 が出力されます。ここでは new 演算子を使用して Fridge クラスのインスタンスを作成する必要はありませんでした。クラスの変数にアクセスしただけです。
-
クラス名を使用してこの静的変数にアクセスし、その値を変更することもできます。出力に 4 が書き出されます。
-
変更できない定数として変数を宣言する場合があります。Apex でこれを行うには final キーワードを使用します。これは、変数への値の割り当てが 1 回限りであることを示します。宣言した静的変数を次のように変更します。引き続き項目の値を出力できます。たとえば、Fridge.STOCK_THRESHOLD; は機能しますが、その他の値を項目に割り当てることはできません。たとえば、Fridge.STOCK_THRESHOLD = 3; は機能しません。
-
では、引数で渡されたオブジェクトの値を出力する静的クラスメソッドを定義してみましょう。これは、デバッグに非常に役立ちます。次のように新しいメソッドを Fridge クラスに追加します。
-
この新しいメソッドをテストするには、開発者コンソールでメソッドをコールし、Fridge インスタンスを渡します。
開発者コンソールには次のように出力されます。
これで、作成したオブジェクトのダンプを簡単に開発者コンソールに表示できるようになりました。