我有一个第三方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"
答案 0 :(得分:82)
假设界面只有一种方法,您可以使用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") }
}
答案 1 :(得分:4)
我有一种情况,我不想为其创建var,而是内联。我实现它的方式是
mnesia
答案 2 :(得分:2)
最简单的答案可能是Kotlin的lambda:
val handler = Handler<MyContext> {
println("Hello world")
}
handler.call(myContext) // Prints "Hello world"
答案 3 :(得分:2)
public static <T> List<T> getPaginatedList(ResultSet resultSet, Mapper<T> mapper,int pageSize) {
List<T> entities=new ArrayList<>();
Result<T> result=mapper.map(resultSet);
IntStream.range(1,pageSize).forEach(i->{
entities.add(result.one());
});
return entities;
}
答案 4 :(得分:0)
从 Kotlin 1.4 开始,您可以声明一个函数式接口:
fun interface Handler<C> {
fun call(context: C);
}
然后你可以简洁地创建一个:
val handler = Handler<String> {
println("Handling $it")
}