伴随对象的构造函数(即主体)中的代码与Java类的静态初始化程序块中的代码 不 完全相同。在下面的示例中,我创建了A的实例,但是没有发生初始化。
scala> object Test { class A; object A { println("A.init") }} defined module Testscala> new Test.Ares3: Test.A = Test$A@3b48a8e6scala> Test.AA.initres4: Test.A.type = Test$A$@6e453dd5
要在创建类的第一个实例时触发伴随对象的构造,可以从类构造函数中访问它。
scala> object Test { class A { A }; object A { println("A.init") }}defined module Testscala> new Test.A A.initres5: Test.A = Test$A@4e94a28escala> new Test.Ares6: Test.A = Test$A@30227d4e
在许多情况下,差异并不重要。但是,如果您要发射导d(或其他副作用),您可能会在意!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)