假设KeyAdapter
是一个抽象类,有几个可以覆盖的方法。
在java中,我可以这样做:
KeyListener keyListener = new KeyAdapter() {
@Override public void keyPressed(KeyEvent keyEvent) {
// ...
}
};
如何在Kotlin中做同样的事情?
答案 0 :(得分:139)
来自the official Kotlin language documentation以及Google首次点击之一:
window.addMouseListener(object : MouseAdapter() {
override fun mouseClicked(e : MouseEvent) {
// ...
}
适用于您手头的问题:
val keyListener = object : KeyAdapter() {
override fun keyPressed(keyEvent : KeyEvent) {
// ...
}
正如Peter Lamberg指出的那样 - 如果匿名类实际上是功能接口的实现(即不是抽象类),SAM Conversions可用于简化此语句更进一步:
val keyListener = KeyAdapter { keyEvent ->
// ...
}
请注意this discussion有关Java和Kotlin中定义的接口的不同用法。
答案 1 :(得分:1)
private Comparator<Integer> comparator = new Comparator<Integer>(){
@Override
public int compare(Integer o1, Integer o2) {
return o1.compareTo(o2);
}
};
private val comparator = object: Comparator<Int> {
override fun compare(o1: Int, o2: Int): Int {
return o1.compareTo(o2)
}
}
但是因为 Comparator 是 FunctionalInterface 我们可以利用 SAM conversions 并写
private val comparator = Comparator<Int> { o1, o2 -> o1.compareTo(o2) }
请注意,SAM 功能仅适用于 Java 中定义的 Functional
接口,如果您需要使用单个方法创建 kotlin object
的 interface
,那么您将不得不使用 object
语法。