148

假设这KeyAdapter是一个抽象类,它有几个可以被覆盖的方法。

在java中我可以这样做:

KeyListener keyListener = new KeyAdapter() {
    @Override public void keyPressed(KeyEvent keyEvent) {
        // ...
    }
};

如何在 Kotlin 中做同样的事情?

4

2 回答 2

223

来自官方 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 中定义的接口的不同用法的讨论。

于 2013-07-07T22:23:12.070 回答
4

在 Java 中

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 中定义的接口,如果您需要使用单一方法创建objectkotlin interface,则必须使用object语法。

于 2021-07-20T16:35:29.373 回答