Bagaimana cara membuat instance antarmuka anonim di Kotlin?

95

Saya memiliki perpustakaan Java pihak ketiga yang objek dengan antarmuka seperti ini:

public interface Handler<C> {
  void call(C context) throws Exception;
}

Bagaimana saya bisa mengimplementasikannya secara ringkas di Kotlin yang mirip dengan kelas anonim Java seperti ini:

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"
Peter Lamberg
sumber

Jawaban:

143

Dengan asumsi antarmuka hanya memiliki satu metode, Anda dapat menggunakan SAM

val handler = Handler<String> { println("Hello: $it") }

Jika Anda memiliki metode yang menerima penangan, Anda bahkan dapat menghilangkan argumen tipe:

fun acceptHandler(handler:Handler<String>){}

acceptHandler(Handler { println("Hello: $it") })

acceptHandler({ println("Hello: $it") })

acceptHandler { println("Hello: $it") }

Jika antarmuka memiliki lebih dari satu metode, sintaksnya sedikit lebih panjang:

val handler = object: Handler2<String> {
    override fun call(context: String?) { println("Call: $context") }
    override fun run(context: String?) { println("Run: $context")  }
}
miensol
sumber
2
acceptHandler { println("Hello: $it")}juga akan bekerja dalam banyak kasus
voddan
5
Untuk siapapun yang berjuang. saya pikir antarmuka harus dideklarasikan di java. saya pikir konversi SAM tidak berfungsi untuk antarmuka kotlin. jika ini adalah antarmuka kotlin Anda harus menggunakan cara {} object: Handler. di sini: youtrack.jetbrains.com/issue/KT-7770 .
j2emanue
2
Anda dapat melakukan ini dengan antarmuka Kotlin mulai 1.4 - Anda cukup mendeklarasikannya sebagai file fun interface.
Nick
18

Saya memiliki kasus di mana saya tidak ingin membuat var untuk itu tetapi melakukannya secara inline. Cara saya mencapainya adalah

funA(object: InterfaceListener {
                        override fun OnMethod1() {}

                        override fun OnMethod2() {}
})
Aalap
sumber
14
     val obj = object : MyInterface {
         override fun function1(arg:Int) { ... }

         override fun function12(arg:Int,arg:Int) { ... }
     }
pruthwiraj.kadam
sumber
2

Jawaban paling sederhana mungkin adalah lambda Kotlin:

val handler = Handler<MyContext> {
  println("Hello world")
}

handler.call(myContext) // Prints "Hello world"
Peter Lamberg
sumber