【编程语言】Kotlin快速入门 - 集合与Lambda

集合

ArrayList给我们提供了一个add方法添加元素,但是在Kotlin使用lambda会简洁很多。

kotlin 复制代码
// 不使用lambda
fun main() {
    var res = ArrayList<String>()
    res.add("1")
    res.add("2")
    res.add("3")
}
kotlin 复制代码
// lambda
fun main() {
    var res = listOf("1", "2", "3")
}

使用listOf时需要注意,其产生的集合是不可变的,如果需要创建可变集合需要使用mutableListOf

Map

Kotlin中的Map写法:

kotlin 复制代码
// 不使用lambda
fun main() {
    var map = HashMap<String, Int>()
    map["a"] = 1
    map["b"] = 2
}
kotlin 复制代码
// lambda
fun main() {
    var map = mapOf("a" to 1, "b" to 2)
}
kotlin 复制代码
// 遍历输出
fun main() {
    var map = mapOf("a" to 1, "b" to 2)
    for ((key, value) in map) {
        println("$key is $value")
    }
}

函数式API

假设我们有一个水果集合。

kotlin 复制代码
fun main() {
    val list = listOf("Apple", "Banana", "Orange", "Pear", "Grape", "Watermelon")
}

我需要求得这个集合里面单词最长的元素,你可能会想到以下代码:

kotlin 复制代码
fun main() {
    val list = listOf("Apple", "Banana", "Orange", "Pear", "Grape", "Watermelon")
    var maxWord = "";
    for (s in list) {
        if (s.length > maxWord.length) maxWord = s
    }
    println("max length : $maxWord" )
}

这样确实能做到,但是在Kotlin中我们可以使用函数式API来让它变得更加精简,它与Java的Stream十分相似。

kotlin 复制代码
fun main() {
    val list = listOf("Apple", "Banana", "Orange", "Pear", "Grape", "Watermelon")
    val maxWord = list.maxBy { m -> m.length }
    println("max length : $maxWord")
}

其中Lambda表达式的语法结构为:

plain 复制代码
{参数名1: 参数类型, 参数名2: 参数类型 -> 函数体}

其实上面提到的maxBy就是一个普通的函数,只不过它接收的是一个Lambda的参数而已,所以我们可以将maxBy的参数单独提取出来:

kotlin 复制代码
fun main() {
    val list = listOf("Apple", "Banana", "Orange", "Pear", "Grape", "Watermelon")
    val la = {m : String -> m.length}
    val maxWord = list.maxBy(la)
    println("max length : $maxWord")
}

此外,Kotlin规定如果Lambda是函数的最后一个参数,可以将Lambda表达式移到函数括号外面,且如果Lambda是唯一一个参数时,函数参数括号可省略:

kotlin 复制代码
fun main() {
    val list = listOf("Apple", "Banana", "Orange", "Pear", "Grape", "Watermelon")
    val maxWord = list.maxBy { m -> m.length }
    println("max length : $maxWord")
}

并且如果Lambda只有一个参数的话(上文代码中的m),其参数可以省略并使用it代替。

kotlin 复制代码
fun main() {
    val list = listOf("Apple", "Banana", "Orange", "Pear", "Grape", "Watermelon")
    val maxWord = list.maxBy { it.length }
    println("max length : $maxWord")
}
Java函数API

这是Java中Runnable接口的源码,它只有一个方法,在Java中Lambda可以写成如下形式:

java 复制代码
@FunctionalInterface
public interface Runnable {
    /**
     * When an object implementing interface <code>Runnable</code> is used
     * to create a thread, starting the thread causes the object's
     * <code>run</code> method to be called in that separately executing
     * thread.
     * <p>
     * The general contract of the method <code>run</code> is that it may
     * take any action whatsoever.
     *
     * @see     java.lang.Thread#run()
     */
    public abstract void run();
}
java 复制代码
    public static void main(String[] args) {
        new Thread(new Runnable() {
            @Override
            public void run() {
                System.out.println("Hello");
            }
        }).start();
    }

但是在Kotlin中,这些代码可以再精简一些,由于Kotlin舍弃了new关键字,所以我们在Kotlin中创建匿名内部类需要使用object关键字。

kotlin 复制代码
fun main() {
    Thread(object : Runnable{
        override fun run() {
            println("Hello!")
        }
    }).start()
}

因为Runnable接口只有一个run方法,所以我们不写函数名称Kotlin也是知道我们的意思就是要实现run方法,这段代码可以再精简一点:

kotlin 复制代码
fun main() {
    Thread(Runnable {
        println("Hello!")
    }).start()
}

不过到这里还没结束,假设Java方法的参数列表中有且仅有一个Java单抽象方法接口参数,那么接口名也是可以省略的,并且按照我们之前提到的,假设Lambda表达式是方法参数的最后一个参数时,实现体可以放在方法括号后面,所以最终被精简的代码如下:

kotlin 复制代码
fun main() {
    Thread {
        println("Hello!")
    }.start()
}
相关推荐
用户298698530148 小时前
Java 实现 Word 文档文本查找与高亮标注
java·后端
宇宙之一粟9 小时前
乐企版式文件生成平台
java·后端·python
plainGeekDev9 小时前
MVC 写法 → MVVM
android·java·kotlin
SL_staff10 小时前
3周搭完MES系统:JVS低代码+JVS-IoT物联网的实战记录
java·前端·低代码
MacroZheng10 小时前
斩获20w star!Claude Code最强插件,AI编程必备!
java·人工智能·后端
唐青枫11 小时前
Java Spring WebFlux 实战指南:用 Mono、Flux 和 WebClient 写响应式接口
java·spring
小bo波1 天前
使用Thread子类创建线程 VS 使用Runnable接口创建线程的区别
java·多线程·thread·并发编程·runnable
SamDeepThinking1 天前
高并发场景下,CompletableFuture与ForkJoinPool该如何取舍?
java·后端·面试
张不才1 天前
CPU 100% 了怎么办?Java 性能排障的标准化操作
java·后端
shepherd1111 天前
吞吐量提升 10 倍:高并发大批量数据处理任务的架构演进与性能调优
java·后端·架构