假设这KeyAdapter
是一个抽象类,它有几个可以被覆盖的方法。
在java中我可以这样做:
KeyListener keyListener = new KeyAdapter() {
@Override public void keyPressed(KeyEvent keyEvent) {
// ...
}
};
如何在 Kotlin 中做同样的事情?
假设这KeyAdapter
是一个抽象类,它有几个可以被覆盖的方法。
在java中我可以这样做:
KeyListener keyListener = new KeyAdapter() {
@Override public void keyPressed(KeyEvent keyEvent) {
// ...
}
};
如何在 Kotlin 中做同样的事情?
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 ->
// ...
}
另请注意有关 Java 和 Kotlin 中定义的接口的不同用法的讨论。
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 转换并编写
private val comparator = Comparator<Int> { o1, o2 -> o1.compareTo(o2) }
请注意,SAM 功能仅适用Functional
于 java 中定义的接口,如果您需要使用单一方法创建object
kotlin interface
,则必须使用object
语法。