Deletions are marked like this. | Additions are marked like this. |
Line 47: | Line 47: |
もちろん、typeやvalだけでなく、defも書ける(はず)。 == 何の役に立つのか? == * 上例からも明らかなように、クラスを指定しなくともその機能が使用できる。ここにはパッケージ全体で共通の定義等を置いておくことができる。でもこれだけでは「素晴らしく便利」とは言えない。 * 例えば、クラスのパッケージを移動したいが後方互換性を残しておきたい場合。 |
パッケージオブジェクト
パッケージオブジェクトの簡単な利用方法
パッケージオブジェクトが無い場合(2.7まで)
すべてをクラス(オブジェクト)の中で定義するしかない。
package foo object Foo { type MOJI = String val SomeString = "hello world" } .... .... import foo.Foo._ object Sample { def main(args: Array[String]) { val a:MOJI = "Greeting:" println(a + SomeString) } }
上例では、例えばStringのエイリアスとしてMOJIを使いたいのだが、それはFooというオブジェクトの中に定義し、それを「import foo.Foo._」としてから使うしかない。
パッケージオブジェクトのある場合(2.8以降)
あたかもパッケージに直接記述できるかのようになる。
package object foo { type MOJI = String val SomeString = "hello world" } ... ... import foo._ object Sample { def main(args: Array[String]) { val a:MOJI = "Greeting:" println(a + SomeString) } }
importする場合は、もはやクラス(オブジェクト)を指定する必要はなく、「import foo._」でよい。 もちろん、typeやvalだけでなく、defも書ける(はず)。
何の役に立つのか?
- 上例からも明らかなように、クラスを指定しなくともその機能が使用できる。ここにはパッケージ全体で共通の定義等を置いておくことができる。でもこれだけでは「素晴らしく便利」とは言えない。
- 例えば、クラスのパッケージを移動したいが後方互換性を残しておきたい場合。