Как создать экземпляр анонимного интерфейса в Котлине?
У меня есть сторонняя библиотека Java, которая имеет объект с таким интерфейсом:
public interface Handler<C> {
void call(C context) throws Exception;
}
Как я могу кратко реализовать его в Kotlin, подобном анонимному классу Java, как это:
Handler<MyContext> handler = new Handler<MyContext> {
@Override
public void call(MyContext context) throws Exception {
System.out.println("Hello world");
}
}
handler.call(myContext) // Prints "Hello world"
Ответы
Ответ 1
Предполагая, что интерфейс имеет только один метод, который вы можете использовать SAM
val handler = Handler<String> { println("Hello: $it")}
Если у вас есть метод, который принимает обработчик, вы можете даже опустить аргументы типа:
fun acceptHandler(handler:Handler<String>){}
acceptHandler(Handler { println("Hello: $it")})
acceptHandler({ println("Hello: $it")})
acceptHandler { println("Hello: $it")}
Если в интерфейсе более одного метода, синтаксис будет немного более подробным:
val handler = object: Handler2<String> {
override fun call(context: String?) { println("Call: $context") }
override fun run(context: String?) { println("Run: $context") }
}
Ответ 2
У меня был случай, когда я не хотел создавать переменную для него, но делал это встроенным. То, как я достиг этого,
funA(object: InterfaceListener {
override fun OnMethod1() {}
override fun OnMethod2() {}
override fun OnPermissionsDeniedForever() {}
})
Ответ 3
Простейшим ответом, вероятно, является лямбда Котлина:
val handler = Handler<MyContext> {
println("Hello world")
}
handler.call(myContext) // Prints "Hello world"
Ответ 4
val obj = object : MyInterface {
override fun function1(arg:Int) { ... }
override fun function12(arg:Int,arg:Int) { ... }
}