apply
在 Scala 中,apply 方法放在类的伴生对象(object)里,主要起到 工厂方法的作用,能够让使用者在创建该类实例时省去显式的 new 关键字,并且可以通过重载提供多种构造方式。
基本案例:
import level02.class09.Logger
object class09 {
/**
* 伴生类和伴生对象 +apply 实现 单例 模式
* 在伴生对象中补充一个apply方法,这样创建对象的时候,就可以省略new
* 伴生类名(参数) ==== 伴生对象名.apply(参数)
*/
// 日志类
class Logger(var filename: String) {
def log(message: String): Unit = {
println(s"Log: $message")
}
}
object Logger {
private var instance: Option[Logger] = None
def apply(filename: String): Logger = {
if (instance.isEmpty) {
instance = Some(new Logger(filename))
}
instance.get
}
}
def main(args: Array[String]): Unit = {
// 省略 new
val log1 = Logger("test.log")
log1.log("2025-11-03 上午上课")
}
}
注释:
在代码中 isEmpty判断是否为空,Some()用来包装一个对象,如果这个对象为空,就得到None对象,否则就返回这个对象。
apply实现单例模式
在上面的基础代码中,我们产生的对象还是在apply中通过new构造出来的,这样的话,如果我们多次生成对象,则得到的对象还是各不相同的。
基本案例:
import java.io.FileWriter
object class10 {
/**
* 伴生类和伴生对象 +apply 实现 单例 模式
* 在伴生对象中补充一个apply方法,这样创建对象的时候,就可以省略new
* 伴生类名(参数) ==== 伴生对象名.apply(参数)
*/
// 日志类
class Logger(var filename: String) {
// 把日志信息写入到文件中
def log(message: String): Unit = {
val writer =new FileWriter(filename, true)
writer.write(s"$message \n")
writer.close()
// println(s"Log: $message")
}
}
object Logger {
private var instance: Option[Logger] = None
def apply(filename: String): Logger = {
if (instance.isEmpty) {
instance = Some(new Logger(filename))
}
instance.get
}
}
def main(args: Array[String]): Unit = {
// 省略 new
val log1 = Logger("test.log")
log1.log("2025-11-03 上午上课")
log1.log("2025-11-03 开运动会")
log1.log("2025-11-07 周末")
}
}