【Kotlin 初学者】字符串常用操作汇总

本文详细介绍了Kotlin中的字符串操作方法,包括substring、subSequence、split、replace等函数的用法、区别和应用场景,以及字符串比较、查找和验证的相关知识。
摘要由CSDN通过智能技术生成

/**

* 返回由给定的 [范围] 索引指定的子字符串。

*/

public fun String.substring(range: IntRange):

//这里需要注意:range.endInclusive + 1

String = substring(range.start, range.endInclusive + 1)

/**

*返回从 [startIndex] 开始到 [endIndex] 之前结束的此字符序列范围中的字符子字符串。

* @param startIndex 起始索引(含)。

* @param endIndex 结束索引(独占)。 如果未指定,则使用字符序列的长度。

*/

@kotlin.internal.InlineOnly

public inline fun CharSequence.substring(startIndex: Int, endIndex: Int = length): String = subSequence(startIndex, endIndex).toString()

/**

* 返回此字符序列的指定 [范围] 索引处的字符子字符串。

*/

public fun CharSequence.substring(range: IntRange): String = subSequence(range.start, range.endInclusive + 1).toString()

看到这里你会发现他们最后调用的还是String.subSequence()函数。这里咱们先看看substring。

//字符串截取

var intercept = “Write better Android apps faster with Kotlin.”

println(intercept.length)//45

println(intercept.substring(10))//er Android apps faster with Kotlin.

println(intercept.substring(10,18))//er Andro

println(intercept.substring(10 until 18))//er Andro

println(intercept.substring(IntRange(10,18)))//er Androi

使用subString(startIndex,endIndex)和subString(rang)时的区别。结合源码和实例可以看出。

下标越界

如上面代码,intercept的字符串长度为45,咱们看下面代码:

println(intercept.substring(30,46))

println(intercept.substring(IntRange(30,46)))

切记下标越界的情况。即StringIndexOutOfBoundsException异常

2.2 subSequence()函数

从当前字符序列返回从startIndex开始到endIndex新的字符序列

var intercept = “Write better Android apps faster with Kotlin.”

println(intercept.length)//45

println(intercept.subSequence(10, 18))//er Andro

三、字符串分割

=======

split函数返回的是List集合数据,Lst集合又支持解构语法特性,它允许你在一个表达式里给多个变量赋值,解构常用来简化变量的赋值。

3.1 使用字符或字符串分割

在实际的项目开发中,不管是Java还是Kotlin这种方式用的要多一些。不过这里值得注意的是,不管是用字符分割,还是字符串分割,其都是一个可变参数。即其参数的个数不定

//字符串分割

var cf = “Android|Java|Kotlin”

var data = cf.split(“|”)

println(data)

这个跟Java类似,只不过返回的是个List集合数据。

解构语法

var cf = “Android|Java|Kotlin”

//解构语法

var (zero, one, two) = cf.split(“|”)

println(“ z e r o − zero- zeroone-$two”)

//解构语法过滤元素,通过_符号过滤掉不想要的元素

//如,不想接收第二个元素则可以用 “_”

var (zero2, _, two2) = cf.split(“|”)

println(“ z e r o 2 − zero2- zero2two2”)

3.2 使用正则表达式分割

在Kotlin中使用正则表达式,使用的是Regex类,而Java中使用正则表达式使用的Pattern类。

var dataRegex = cf.split(Regex(“[ao]”))

//[Andr, id|J, v, |K, tlin]

println(dataRegex.toString())

dataRegex = cf.split(Pattern.compile(“[ao]”))

//[Andr, id|J, v, |K, tlin]

println(dataRegex.toString())

四、字符串替换

=======

Kotlin除了实现Java中的replace()函数外,还提供了另外的replaceFirst()、replaceAfter()、replaceBefore()、replaceIndent()等函数。

4.1 replace()函数

replace()函数提供了4个重载函数。他们能实现不同的功能

4.1.1 replace(oldValue: String, newValue: String, ignoreCase: Boolean = false)

把原字符串中的某一个字符全部替换成新的字符。然后返回新的字符串

  • oldChar: 需要替换的字符

  • newChar: 新的字符

  • ignoreCase : 是否引用Java中的replace()函数。默认值为false,即用Java的replace()函数

var th = “Write better Android apps faster with Kotlin.”

// 把字符t全部替换为!

println(th)

println(th.replace(“t”, “!”))

4.1.2 replace(regex: Regex, noinline transform: (MatchResult) -> CharSequence)

根据定义的正则规则去匹配源字符串,把满足规则的字符串通过transform{}高阶函数映射的新字符串替换。

  • regex: 正则表达式,用来决定要替换哪些字符

  • transform: 高阶函数(匿名函数,用来确定该如何替换正则表达式搜索到的字符)

var reg= th.replace(Regex(“[rte]”)){

when(it.value){

“r” ->“7”

“t” ->“!”

“e” ->“5”

else -> it.value

}

}

println(reg)

其他两个函数就不占用篇幅了,用法是一样的。

4.2 replaceFirst()函数

把满足条件的第一个字符或字符串替换成新的字符或字符串。

//把第一个字符A替换为V

println(th.replaceFirst(“e”, “V”))

//把第一个字符串er替换为Victory

println(th.replaceFirst(“er”, “Victory”))

4.3 replaceAfter()函数

截取满足条件的第一个字符或字符串前面的字符串,包含满足条件字符或字符串自身,并在其后面加上新的字符串。

//截取字符p,并在其后面加上Kotlin

println(th.replaceAfter(“p”, “Kotlin”))

//截取字符串Android,并在其后面加上帅次

println(th.replaceAfter(“Android”, “帅次”))

4.4 replaceBefore()函数

截取满足条件的第一个字符或字符串后面的字符串,包含满足条件字符或字符串自身,并在其前面加上新的字符串

//截取字符p,并在其前面加上Kotlin

println(th.replaceBefore(“p”, “Kotlin”))

//截取字符串Android,并在其前面加上帅次

println(th.replaceBefore(“Android”, “帅次”))

4.5 replaceIndent()函数

检测常见的最小缩进,并将其替换为指定的 newIndent。

var indent  = "            aaa       aaaA"

println(indent)

//检测常见的最小缩进,并将其替换为指定的 newIndent。

println(indent.replaceIndent())

//检测所有输入行的通用最小缩进,将其从每一行中删除,如果第一行和最后一行是空白的,也将其删除(注意空白与空的区别)

println(indent.trimIndent())

五、字符串比较

=======

在Kotlin中,用 == 检查两个字符串中的字符是否匹配,用 === 检查两个变量是否指向内存堆上同一对象,而在Java中 == 做引用比较,做内容比较时用equals方法。

=====

//字符串比较

val str1 = “Kotlin”

val str2 = “Kotlin”

val str3 = “kotlin”.replace(“k”,“K”)

println(“ s t r 1 − str1- str1str2-$str3”)

//比较的是内容,true

println(str1 == str2)//true

println(str1 == str3)//true

//这里为什么是true,字符串内容不可变,Java和Kotlin有个字符串常量池

println(str1 === str2)//true

println(str1 === str3)//false

常量池:是为了方便快捷地创建某些对象而出现的,当需要一个对象时,就可以从池中取一个出来(如果池中没有则创建一个),则在需要重复创建相等变量时节省了很多时间。常量池其实也就是一个内存空间,常量池存在于方法区中。

String类也是Java中用得多的类,同样为了创建String对象的方便,也实现了常量池的技术。

equals

val str1 = “Kotlin”

val str2 = “Kotlin”

val str4 = “kotlin”

println(str1.equals(str2))//true

println(str1.equals(str4))//false

//第二个参数加true代表忽略大小写比较。

//第二个参数加false代表不忽略大小写比较。

println(str1.equals(str4,true))//true

六、字符串查找

=======

6.1 获取第一个元素

6.1.1 first()函数和first{}函数

var seek = “Write better Android apps faster with Kotlin.”

println(seek.first())

//查找等于某一个字符的第一个元素

var data = seek.first {

it == ‘A’

}

println(data)

在这里介绍一下firstOrNull()函数firstOrNull{}函数

  • 如果字符串为空串时,first()函数会抛出异常,而firstOrNull()函数会返回null。

  • 如果字符串为空串时,first{}函数会抛出异常,而firstOrNull{}函数会返回null

6.1.2 firstOrNull()函数和firstOrNull{}函数

seek = “”

//报错:NoSuchElementException: Char sequence is empty.

//    println(seek.first())

println(seek.firstOrNull())//null

//如果字符串为空串或字符串内没有该字符,则返回null

var foN= seek.firstOrNull {

it == ‘N’

}

println(foN)//null

seek = “Note”

//满足条件返回:char=N

foN= seek.firstOrNull {

it == ‘N’

}

println(foN)//N

6.2 获取最后一个元素

seek = “Note”

println(seek.last())//e

var la = seek.last {

it == ‘t’

}

println(la)//t

lastOrNull()firstOrNull()类似。lastOrNull{}firstOrNull{}类似。

6.3 查找元素

  • indexOf() : 查找某一个元素或字符串在原字符串中第一次出现的下标。

  • indexOfFirst{}: 同indexOf()。

  • lastIndexOf(): 查找某一个元素或字符串在原字符串中最后一次出现的下标。

  • indexOfLast{}: 同lastIndexOf()。

val cz = “Android|Java|Kotlin”

//查找i在cz中第一次出现的下标。

println(cz.indexOf(‘i’))//5

println(cz.indexOf(“i”))//5

//从第10位开始,查找i在cz中第一次出现的下标。

println(cz.indexOf(“i”, 10))//17

var z = cz.indexOfFirst {

it == ‘i’

}

println(z)//5

//查找i在cz中最后一次出现的下标。

println(cz.lastIndexOf(‘i’))//17

println(cz.lastIndexOf(“i”))//17

//从第10位开始,查找i在cz中第一次出现的下标。

println(cz.lastIndexOf(“i”, 10))//5

z = cz.indexOfLast {

it == ‘i’

}

println(z)//17

七、字符串验证

=======

在实际的开发中,特别是Android开发中,会经常遇到验证输入框的内容是否为空串的时候。

下列几个函数都是处理字符串为空串或为空的:

  • isEmpty(): 其源码是判断其length是等于0,若等于0则返回true,反之返回false。不能直接用于可空的字符串

  • isNotEmpty(): 其源码是判断其length是否大于0,若大于0则返回true,反之返回false。不能直接用于可空的字符串

  • isNullOrEmpty(): 其源码是判断该字符串是否为null或者其length是否等于0。

  • isBlank(): 其源码是判断其length是否等于0,或者判断其包含的空格数是否等于当前的length。不能直接用于可空的字符串

  • isNotBlank(): 其源码是对isBlank()函数取反。不能直接用于可空的字符串

  • isNotOrBlank(): 其源码判断该字符串是否为null。或者调用isBlank()函数

var verification = “”

println(verification)

println(verification.isEmpty())//true

println(verification.isNotEmpty())//false

println(verification.isNullOrEmpty())//true

println(verification.isBlank())//true

println(verification.isNotBlank())//false

println(verification.isNullOrBlank())//true

verification = “Kotlin”

println(verification)

println(verification.isEmpty())//false

println(verification.isNotEmpty())//true

println(verification.isNullOrEmpty())//false

println(verification.isBlank())//false

println(verification.isNotBlank())//true

println(verification.isNullOrBlank())//false

八、大杂烩

=====

8.1 字符串拼接

  • 使用+

  • 使用plus()函数

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

尾声

对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。 整理的这些架构技术希望对Android开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。

最后想要拿高薪实现技术提升薪水得到质的飞跃。最快捷的方式,就是有人可以带着你一起分析,这样学习起来最为高效,所以为了大家能够顺利进阶中高级、架构师,我特地为大家准备了一套高手学习的源码和框架视频等精品Android架构师教程,保证你学了以后保证薪资上升一个台阶。

  • 思维脑图
  • 性能优化学习笔记


  • 性能优化视频

    当你有了学习线路,学习哪些内容,也知道以后的路怎么走了,理论看多了总要实践的。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

笔记、源码讲义、实战项目、讲解视频,并且会持续更新!**

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

尾声

对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。 整理的这些架构技术希望对Android开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。

最后想要拿高薪实现技术提升薪水得到质的飞跃。最快捷的方式,就是有人可以带着你一起分析,这样学习起来最为高效,所以为了大家能够顺利进阶中高级、架构师,我特地为大家准备了一套高手学习的源码和框架视频等精品Android架构师教程,保证你学了以后保证薪资上升一个台阶。

  • 思维脑图
    [外链图片转存中…(img-vwm9gNJa-1712831058000)]
  • 性能优化学习笔记
    [外链图片转存中…(img-HSlkKtXV-1712831058000)]
    [外链图片转存中…(img-TOdeoQc8-1712831058001)]

[外链图片转存中…(img-pbblGqPV-1712831058001)]
[外链图片转存中…(img-3GQmRegk-1712831058001)]

  • 性能优化视频
    [外链图片转存中…(img-Op926L9A-1712831058001)]
    当你有了学习线路,学习哪些内容,也知道以后的路怎么走了,理论看多了总要实践的。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值