网站建立公司,重庆造价工程信息网官网,中国设计网站推荐,网店开店流程kotlin之::函数调用、plus#xff08;增加元素#xff09;、copyOf#xff08;复制数组#xff09;、reverse#xff08;翻转数组#xff09;、forEach#xff08;遍历数组#xff09;、filter#xff08;过滤数组#xff09;、map函数操作及扩展、reduce函数、fold函…kotlin之::函数调用、plus增加元素、copyOf复制数组、reverse翻转数组、forEach遍历数组、filter过滤数组、map函数操作及扩展、reduce函数、fold函数、filter、filterIndexed、takeWhile、infix关键字等的解释和使用示例。 说明已经在代码里面了请看代码。如果有任何疑问或者建议可以留言。谢谢。 函数的其它用法::操作函数的其它方式。 class ComposeCall {fun sayHi() {System.out.println(ComposeCall,sayHi:Hi!)}fun sayHiToAny(any: Any) {System.out.println(---ComposeCall,sayHiToAny:Hi, any)}
}
复制代码验证 var hi1 ComposeCall::sayHiToAny//返回的是方法本身而不是返回值println(hil: hi1)//输出
// hil:fun com.tanksu.ndkdemo3.feature.cls.ComposeCall.sayHiToAny(kotlin.Any): kotlin.Unitvar hi2 ComposeCall::sayHivar com ComposeCall()hi2(com)//必须要传入类的实例才能够进行调用相当于java的invoke一样hi1(com, jack)//传入类实例和参数相当于java的invoke方法去调用hi2以及入参//输出
// ComposeCall,sayHi:Hi!
// ---ComposeCall,sayHiToAny:Hi,jack
复制代码数组操作之plus增加元素、copyOf复制数组、reverse翻转数组、forEach遍历数组、filter过滤数组等方法对数组的操作。 val arr arrayOf(Apple, Banana, , Orange)arr.forEach(::println)//空对象也输出了println(--------------------------)var narr arr.plus(juice)//这里必须用另外一个对象来接收原来的对象不会改变var newArr narr.copyOf()//复制一份新的arrnewArr.forEach(::println)println(--------------------------)arr.reverse()//将数组翻转过来arr.forEach(::println)println(--------------------------)println(arr.filter(String::isNotEmpty))//filter将会过滤不为空的对象
// Apple
// Banana
//
// Orange
// --------------------------
// Apple
// Banana
//
// Orange
// juice
// --------------------------
// Orange
//
// Banana
// Apple
// --------------------------
// [Orange, Banana, Apple]
复制代码list的map函数操作及扩展对数组进行自定义操作。 val raw listOf(1, 2, 3, 4, 5, 5)val newList ArrayListInt()raw.forEach {newList.add(it 1)//it替代raw中每一个元素这里一次加入到newList中}println(newList)println(raw.map { it * 10 })//map先遍历raw的元素然后再执行打印动作println(raw.map(Int::toDouble))//map先将每个元素都变成double类型然后再执行打印动作
// [2, 3, 4, 5, 6, 6]
// [10, 20, 30, 40, 50, 50]
// [1.0, 2.0, 3.0, 4.0, 5.0, 5.0]
复制代码数组的reduce函数遍历数组元素并自定义操作。和fold类似。 val list listOf(2, 3, 5)println(list.reduce { ret, i - ret i })//第一个参数ret是结果第二个参数是代表要执行的操作// 比如我这里是数组每个元素相乘最后吧结果输出给ret。。。。下面我将进行加法操作如下//输出30//加法操作println(list.reduce { ret, i - ret i })//输出10
复制代码数组的fold函数用法对数组进行进行自定义操作。和reduce类似。 val list listOf(2, 3, 5)println(--------------------------)println(raw.fold(10) { ret, i - ret i })//这里给了一个初始值10然后fold操作和reduce操作类似println(raw.fold(StringBuilder(jack say:)) { ret, i - ret.append(i) })//这里也给了一个初始值StringBuilder// 在第二个参数里面才能够进行append操作//输出结果
// --------------------------
// 20
// jack say:235
复制代码数组方法之filter、filterIndexed、takeWhile等对数组元素操作。 val list listOf(4, 3, 2, 5, 6, 8, 9)println(list.filter { it 3 || it 6 })//过滤等于3或者等于6的元素集合结果以新的集合返回println(list.filterIndexed { index, i - index i })//过滤等于第一个参数的元素集合结果以新的集合返回println(list.takeWhile { it in 0..5 })//过滤在0-5之间的元素结果以新的集合返回println(list.takeWhile { it in 3..5 })//过滤在3-5之间的元素结果以新的集合返回。这里加入判断到其中一个元素不满足条件就会终止执行下面的元素判断//输出结果
// [3, 6]
// [2]
// [4, 3, 2, 5]
// [4, 3]
复制代码infix的关键字解释函数的另外一种调用手法。骚操作 class TestInfix(var age: Int) {infix fun dog(weight: Int) {println(TestInfix, dog $age and $weight)}infix fun cat(weight: String) {println(TestInfix, dog $age and $weight)}}infix fun TestInfix.rat(mounth: Int) {//这是println(TestInfix rat $age and $mounth)}var i TestInfix(3)i dog 80i rat 1i cat jack
// TestInfix, dog 3 and 80
// TestInfix rat 3 and 1
// TestInfix, dog 3 and jack
复制代码非空判断 用 ? 调用是安全调用,在被调用的量为空时也返回null
用 !! 调用的是假定非空调用,在被调用的量为空时会发起空指针异常(NPE)
或者直接用条件判断(if-else)来事先决定好空量的处理方案
复制代码