Kotlin中常见的List使用

文章目录

    • 1.filter
    • 2.map
    • 3.count
    • 4.first,last
    • 5.any,all,none
    • 6.find,findLast
    • 7.indexOf()和lastIndexOf()查找元素下标
    • 8.Slice切片
    • 9.Take()和drop()获取指定长度

1.filter

filter 就像其本意一样,可以通过 filter 对 Kotlin list 进行过滤。

fun main()
{val numbers = listOf(1, -2, 3, -4, 5, -6)val positives = numbers.filter { x -> x > 0 }val negatives = numbers.filter { it < 0 }      // 这里我们可以使用 it println("positive values: ${positives}")        // 打印 positive values: [1, 3, 5]println("negative values: ${negatives}")        // 打印 positive values: [-2, -4, -6]
}

2.map

map扩展函数能使我们能够变化应用于集合中的所有元素

fun main()
{val numbers = listOf(1, -2, 3, -4, 5, -6)     val doubled = numbers.map { x -> x * 2 }val tripled = numbers.map { it * 3 }          println("doubled values: ${doubled}")       // 打印 doubled values: [2, -4, 6, -8, 10, -12]println("tripled values: ${tripled}")       // 打印 tripled values: [3, -6, 9, -12, 15, -18]
}

3.count

count函数返回集合中的元素总数或与给定条件匹配的元素数。

fun main()
{val numbers = listOf(1, -2, 3, -4, 5, -6)val totalCount = numbers.count() //集合中的元素总数                    val evenCount = numbers.count { it % 2 == 0 }  //与给定条件匹配的元素数      println("totalCount: ${totalCount}")    // 打印 totalCount: 6println("evenCount: ${evenCount}")      // 打印 evenCount: 3
}

4.first,last

返回列表中第一个或最后一个元素的值。

fun main()
{val numbers = listOf(1, -2, 3, -4, 5, -6)            val first = numbers.first()                          val last = numbers.last()                            val firstEven = numbers.first { it % 2 == 0 }        val lastOdd = numbers.last { it % 2 != 0 }                  println("first element: ${first}")          // 打印 first element: 1println("last element: ${last}")            // 打印 last element: -6println("first Even element: ${firstEven}") // first Even element: -2println("last Odd element: ${lastOdd}")     // last Odd element: 5
}

5.any,all,none

这些函数检查是否存在与给定条件匹配的集合元素,并返回布尔值。
any:集合中存有一个或多个元素符合条件时返回true,否则返回false
all:当且仅当该集合中所有元素都满足条件时,返回true;否则都返回false。
node:如果集合中没有符合匹配条件的元素,返回true,否则返回false

fun main()
{val numbers = listOf(1, -2, 3, -4, 5, -6)            val anyNegative = numbers.any { it < 0 }             val anyGT6 = numbers.any { it > 6 }                  val allEven = numbers.all { it % 2 == 0 }            val allLess6 = numbers.all { it < 6 }  val allEven = numbers.none { it % 2 == 1 }           val allLess6 = numbers.none { it > 6 }               println("any negative elements: ${anyNegative}")    // 打印 any negative elements: trueprintln("any elements larger than six: ${anyGT6}")  // any elements larger than six: falseprintln("是否所有元素都是双数:${allEven}")           // 是否所有元素都是双数:falseprintln("是否所有元素都小于6: ${allLess6}")           // 是否所有元素都小于6: true
}

6.find,findLast

find和findLast函数返回与给定条件匹配的第一个或最后一个集合元素。如果没有这样的元素,函数将返回null

fun main(string: Array<String>) {val test = listOf("one", "two", "three", "four", "five", "six")//从开头查询,字符长度大3的元素println(test.find {it.length > 2})println(test.findLast { it.length > 3 })
}
//输出
one
five

7.indexOf()和lastIndexOf()查找元素下标

在列表中,都可以使用indexOf() 或者lastIndexOf() 查询到元素在集合中的位置。
如果集合中没有该对象,则返回-1。

fun main(string: Array<String>) {val numbers = listOf(1, 2, 3, 4, 2, 5)println(numbers.indexOf(2))println(numbers.lastIndexOf(2))
}
//输出
1
4

还有一种扩展方法

  • indexOfFirst()返回与关键字匹配的第一个元素的索引,如果没有此类元素,则返回 -1。
  • indexOfLast() 返回与谓词匹配的最后一个元素的索引,如果没有此类元素,则返回 -1。
fun main(string: Array<String>) {val numbers = mutableListOf("A", "B", "B", "C", "C", "A", "C")println(numbers.indexOfFirst { it == "A" })println(numbers.indexOfLast { it == "A" })
}
//输出
0
5

8.Slice切片

该函数返回具有给定索引的集合元素列表。

fun main(string: Array<String>) {//我们得到一个字符串数组val test = listOf("A", "B", "C", "D", "E", "F", "G")val temp = test.slice(listOf(1,4,3))println(temp)
}
//输出
[B, E, D]

我们注意到,截取后的集合,也是按照我们传入的下标顺序进行获取的。
索引既可以是作为集合的形式传入,也可以是[区间]

fun main(string: Array<String>) {//我们得到一个字符串数组val test = listOf("A", "B", "C", "D", "E", "F", "G")//截取 下标从2 到4的 集合集val temp = test.slice(2..4)println(temp)//截取 步长为2的 指定区间的参数val temp1 = test.slice(2..4 step 2)println(temp1)
}
//输出
[C, D, E]
[C, E]

9.Take()和drop()获取指定长度

slice在使用的过程中可能会越界。
而take 和drop截取的时候不会产生越界的问题。

  • take :从头开始获取指定长度的元素,如果原始集合长度不够,则返回整个集合对象。
  • drop:从指引位置开始截取到集合尾部。
fun main(string: Array<String>) {//我们得到一个字符串数组val test = listOf("A", "B", "C", "D", "E", "F", "G")//从头截取val temp = test.take(5)println(temp)//从下标2的元素开始, 包括下标2的元素本身val temp1 = test.drop(2)println(temp1)
}
//输出
[A, B, C, D, E]
[C, D, E, F, G]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/173739.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

03_歌词滚动效果

03_歌词滚动效果 文章目录 03_歌词滚动效果效果一、数据准备①&#xff1a;歌词②&#xff1a;音频等 二、代码实现①&#xff1a;首页②&#xff1a;样式③&#xff1a;js逻辑④&#xff1a;测试 效果 一、数据准备 ①&#xff1a;歌词 var lrc [00:00.95]夜微凉 - 徐珊 [0…

Glare or Gloom, I Can Still See You – End-to-End Multi-Modal Object Detection

SENSOR-AWARE MULTI-MODAL FUSION G-log(-log(U))&#xff0c;U&#xff5e;Uniform[0,1] 辅助信息 作者未提供代码

用python自行开发的流星监控系统meteor_monitor(第一篇)

代码&#xff1a; https://github.com/xingxinghuo1000/meteor_monitor_scripts.git 由于代码做了较大调整&#xff0c;废弃了sikuli部分。本篇文章为旧的&#xff0c;不要看了&#xff0c;最新文章请看&#xff1a; 用python自行开发的流星监控系统meteor_monitor&#xff0…

【解决方案】安科瑞智能照明系统在福建二建大厦项目上的研究与应用

【摘要】&#xff1a;智能化已经成为当今建筑发展的主流技术、涵盖从空调系统、消防系统到安全防范系统以及完善的计算机网络和通信系统。但是长期以来、智能照明在国内一直被忽视、大多数建筑物仍然沿用传统的照明控制方式、部分智能大厦采用楼宇自控&#xff08;BA&#xff0…

Java 8新特性Optional的使用以及判空案例

Java 8新特性&#xff1a;Optional的使用及判空案例 在Java 8中&#xff0c;引入了一个重要的类Optional&#xff0c;它是为了解决空指针异常&#xff08;NullPointerException&#xff09;而设计的。Optional可以作为一个容器&#xff0c;可以包含一个非空的值或者为空。 Opti…

锂电池污水如何处理

锂电池是目前应用广泛的重要电池类型&#xff0c;然而其生产过程和废弃处理中产生的污水对环境造成了不可忽视的影响。本文将探讨锂电池污水的处理方法&#xff0c;以期为环境保护和可持续发展作出贡献。 首先&#xff0c;了解锂电池污水的组成是解决问题的关键。锂电池污水通…

防雷接地电阻和接地网的区别及其应用

接地是电气工程中的一种重要的安全措施&#xff0c;它可以保护电气设备和人员免受雷击和过电压的危害&#xff0c;也可以提高电气系统的运行稳定性和可靠性。接地的基本原理是将电气设备或人体与大地连接成同一电位&#xff0c;从而消除或减小危险电压。 地凯科技接地的实现方式…

PHP 针对人大金仓KingbaseES自动生成数据字典

针对国产数据库 人大金仓KingbaseES 其实php 连接采用pdo方式 必须&#xff1a;需要去人大数据金仓官方网站 下载对应版本的pdo_kdb 扩展驱动 其连接方法与pgsql 数据库连接方法大致相同 不解释 直接上代码&#xff1a; <?php /*** 生成人大金仓数据字典*/ header(…

【Android知识笔记】性能优化专题(五)

App瘦身优化 随着业务迭代,apk体积逐渐变大。项目中积累的无用资源,未压缩的图片资源等,都为apk带来了不必要的体积增加。而APK 的大小会影响应用加载速度、使用的内存量以及消耗的电量。 瘦身优势: 最主要是转换率:下载转换率头部 App 都有 Lite 版渠道合作商要求了解 …

上海亚商投顾:北证50指数大涨 逾百只北交所个股涨超10%

上海亚商投顾前言&#xff1a;无惧大盘涨跌&#xff0c;解密龙虎榜资金&#xff0c;跟踪一线游资和机构资金动向&#xff0c;识别短期热点和强势个股。 一.市场情绪 沪指11月24日震荡调整&#xff0c;深成指、创业板指盘中跌超1%。北证50指数大涨超6%&#xff0c;北交所个股持…

BGP路由的选路综合实验

题目要求 1.使用PreVal策略&#xff0c;确保R1通过R3到达192.168.10.0/24 2.使用AS_Path策略&#xff0c;确保R1通过R3到达192.168.11.0/24 3.配置MED策略&#xff0c;确保R1通过R3到达192.168.12.0/24 4.使用Local Preference策略&#xff0c;确保R4通过R2到达192.168.1.0/24…

git-2

1.分离头指针情况下的注意事项 分离头指针指的是变更没有基于某个branch去做&#xff0c;所以当进行分支切换的时候&#xff0c;在分离头指针上产生的commit&#xff0c;很可能会被git当作垃圾清理掉&#xff0c;如果你认为是重要的内容&#xff0c;切记需要绑定分支 2.进一步…

2023机器人灵巧手的分类与商业化应用及未来市场规模分析报告

今天分享的是机器人系列深度研究报告&#xff1a;《2023机器人灵巧手的分类与商业化应用及未来市场规模分析报告》。 &#xff08;报告出品方&#xff1a;深度行业分析研究&#xff09; 报告共计&#xff1a;26页 1 灵巧手是人形机器人重要的运控交互部件&#xff0c;近年来海…

MyBatis-Plus条件构造器

说明 Wrapper&#xff1a;条件构造抽象类&#xff0c;最顶端父类AbstractWrapper&#xff1a;用于查询条件封装&#xff0c;生成sql的where条件QueryWrapper&#xff1a;查询条件封装UpdateWrapper&#xff1a;更新条件封装AbstractLambdaWrapper&#xff1a;使用Lambda语法La…

Sass中如何使用选择器继承来精简CSS详细教程

文章目录 前言使用选择器继承来精简CSS何时使用继承继承的高级用法继承的工作细节使用继承的最佳实践后言 前言 hello world欢迎来到前端的新世界 &#x1f61c;当前文章系列专栏&#xff1a;Sass和Less &#x1f431;‍&#x1f453;博主在前端领域还有很多知识和技术需要掌握…

和鲸ModelWhale平台与海光人工智能加速卡系列完成适配认证,夯实 AI 应用核心底座

AIGC 浪潮席卷&#xff0c;以大模型为代表的人工智能发展呈现出技术创新快、应用渗透强、国际竞争激烈等特点。创新为本&#xff0c;落地为王&#xff0c;技术的快速发展与大规模训练需求的背后&#xff0c;是对平台化基础设施与 AI 算力的更高要求。在此全球 AI 产业竞争的风口…

BI报表用多了,就再看不了其他报表

BI报表有魔力&#xff0c;一旦用多了&#xff0c;就再也接受不了其他的报表。为什么&#xff1f;我这就来总结说说。 1、分析的效率 一般报表&#xff1a;要做报表&#xff0c;先找IT取数&#xff0c;然后开发&#xff0c;分析过程中有新需求&#xff0c;不好意思&#xff0c…

六道经典的选择结构题型

1. 判断一个数是奇数还是偶数 #include <stdio.h> int main() { int num; printf("请输入一个整数&#xff1a;"); scanf("%d", &num); if (num % 2 0) { printf("%d是偶数\n", num); } else { …

Vue组件库推荐:Element UI深度解析

在Vue开发中&#xff0c;使用组件库可以极大地提高开发效率&#xff0c;减少重复工作量。Element UI作为一款优秀的Vue组件库&#xff0c;被广泛应用于各类项目中。本文将对Element UI进行深度解析&#xff0c;为开发者提供详细的使用说明和具体的代码示例。 1&#xff0c;Ele…

fatal: refusing to merge unrelated histories報錯咋辦

在 Git 中&#xff0c;如果要合并两个分支&#xff0c;而这两个分支的历史记录不相交&#xff0c;就会出现错误&#xff1a;fatal: refusing to merge unrelated histories。 要解决这个问题&#xff0c;有以下几种方法&#xff1a; 首先&#xff0c;检查一下你正在合并的两个…