首先给大家分享一个交流平台http://kotlin.cn/
由于我的Android项目在转换Kotlin编码后我定义的反射机制崩溃了,一直报错不断,所以我觉得看看它的官方文档,由于英文文档我看着吃力,我找到了一个编译的中文文档,看着还不错比较全面就是错别字很多,还有部分源码有问题,我发现的会在下面讲解时矫正过来,这是网址https://huanglizhuo.gitbooks.io/kotlin-in-chinese/content/Other/Reflection.html。
由于我遇到的是反射机制的问题,所以我重点看了文档中对kotlin反射部分的内容,得到了如下心得与大家分享:
首先我要说一说的就是函数引用,它的函数的声明简洁清晰,这是kotlin让我非常喜欢。
例:函数声明 fun isOdd(x:Int)=x % 2 !=0,看到这里会不会又看不懂的开始吐槽了,别急我给大家解释一下,fun isOdd(x:Int)是声明的函数,其中isOdd是函数名也可以说是方法名而fun 可以理解为修饰符,(x:Int)则是参数参数名为x类型为int,后面的这部分=x % 2 !=0,第一个=后的内容为函数体就是x % 2 !=0,这样一看大家应该都看懂了吧?是不是感觉很简洁,这个函数体是判断输入值是否为偶数。
前面的函数引用不是我要说的重点,我要说的是函数组合
首先我们在写一个函数 fun length(s: String) = s.length,这个函数我们是输入字符串返回一个字符串的长度值,下面我们将这个函数与上面讲到的函数组合起来使用,这时我们需要设置一个组合器,代码如下:
fun <A,B,C>compose(f: (B) ->C, g: (A) ->B): (A) ->C { return { x->f( g(x) ) } }
到这里是不是又感觉有点乱了,我来帮你理理思路,首先我们还是分为2部分我们将函数体先剔出去fun <A,B,C>compose(f: (B) ->C, g: (A) ->B): (A) ->C { } 然后我们来看下参数(f: (B) ->C, g: (A) ->B)这两个参数分别为f: (B) ->C和g: (A) ->B,这两个参数大家可以理解为一元一次函数g公式未知数A得到值为B,f公式未知数为B得到值为C,这时我们再看函数体{return { x->f( g(x) ) } }我们输入x先经过g(x)公式得到值,再将这个值作为f(x)公式输入的x进行运算得到最终输出值也就是C。
这会都清楚了吧,那这个函数组合又如何来用呢?
val oddLength = compose(::isOffet, ::length) //val是kotlin的常量修饰符,::表示引用方法值
val strings =listOf("a","ab","abc") //得到一个字符串集合
Log.i("log","strings--"+strings.filter(oddLength)) //输出结果 [a, abc]