Suk*_*aar 1 java scala static-block classloader apache-spark
scala 是否有类似于类加载器对 java 中的静态块所做的事情?
例如,scala 中类似于下面的内容:
class A{
static{
System.out.println("This gets called at the time of loading a class by class loader.")
}
}
Run Code Online (Sandbox Code Playgroud)
我正在使用 Scala 2.x 和 Apache Spark 2.x
PS:我已经读过什么是Scala相当于Java的静态块?这个答案,但我不想创建伴生对象,然后通过类的构造函数调用它。
编辑:[我的用例]
考虑java的一个场景,我们在静态块中编写Class.forName(“some.jdbc.driver”),然后将jdbc驱动程序放在类路径中。之后类加载器加载我们提到的类。我想做一些完全一样的事情
编辑:没有人抱太大希望,所以这里有一个@static 成员的 SIP链接。它已经为 Dotty/Scala 3 实现了。
但是,成员是在同伴上定义的。成员定义的 RHS 可以包含任意代码,因此不需要静态初始值设定项的语法。
仍然想知道有什么用例。
您的用例是什么?
按说:
scala 2.13.0-M4> object X { println("hi") }
defined object X
scala 2.13.0-M4> X
hi
res0: X.type = X$@554c4eaa
scala 2.13.0-M4> :javap -c X
Compiled from "<console>"
public class $line3.$read$$iw$$iw$X$ {
public static $line3.$read$$iw$$iw$X$ MODULE$;
public static {};
Code:
0: new #2 // class $line3/$read$$iw$$iw$X$
3: invokespecial #20 // Method "<init>":()V
6: return
public $line3.$read$$iw$$iw$X$();
Code:
0: aload_0
1: invokespecial #21 // Method java/lang/Object."<init>":()V
4: aload_0
5: putstatic #23 // Field MODULE$:L$line3/$read$$iw$$iw$X$;
8: getstatic #28 // Field scala/Predef$.MODULE$:Lscala/Predef$;
11: ldc #30 // String hi
13: invokevirtual #34 // Method scala/Predef$.println:(Ljava/lang/Object;)V
16: return
}
Run Code Online (Sandbox Code Playgroud)
为了让您相信这是普通的静态加载:
scala 2.13.0-M4> :pa -raw
// Entering paste mode (ctrl-D to finish)
package y { object Y { println("hi") } }
// Exiting paste mode, now interpreting.
scala 2.13.0-M4> Class.forName
def forName(x$1: String,x$2: Boolean,x$3: ClassLoader): Class[_] def forName(x$1: String): Class[_]
scala 2.13.0-M4> Class.forName("y.Y$", true, getClass.getClassLoader)
hi
res5: Class[_] = class y.Y$
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
797 次 |
| 最近记录: |