个人笔记,勿吐槽,谢谢!一切都是为了进步...
*****************************记录一下,我被kotlin搞死的细节******************************
1.个人神坑一:用传统的android代码创建了android demo,添加了base依赖module,将
applyplugin:'kotlin-android'
compile"org.jetbrains.kotlin:kotlin-stdlib-jre7:$kotlin_version"
compile"org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version"
这些对应的kotlin的插件和版本从app应用统一移到base module当中,这时候,运行app至手机,报错(Caused by: java.lang.NoClassDefFoundError: Class not found using thebootclassloader; no stack trace available) ---类似于android一开始超过64k丢失class文件的错误,这时候跟我以往的经验,加上MultiDex应该就能解决,但加上之后无效果,之后分析apk,发现class.dex文件当中,base包下的所有文件加载完毕,而app包下的所有kt文件未生成class文件,未加载进入dex文件,迷之尴尬,想尽各种办法,无解。
解决方案:受原先jdk编译器思路的影响,未注意到,这时候生成的activity或者application等app包下的所有文件都得通过kotlin编译器中间一层编译成class文件,所以这时候考虑到是不是app 这个module没有应用kotlin插件这句话导致这个问题,如是在build.gradle文件当中添加applyplugin:'kotlin-android'这句话,解之。瞬间一口老血飙出千里,我NM...
总结:kotlin android项目目录的每个module都得添加apply plugin:'kotlin-android'应用插件,恭喜自己涨了见识,厉害了! word 哥,也怪自己瞎倒腾,请容许我为自己默哀一分钟。
**************************************几种操作符的区分*****************************************
val a:String? = null -->当一个变量值可为null的时候,必须在声明处的类型后添加?来标识该引用可为空。
b?.length -->安全调用符(?.),一般运用在链式调用中,如果调用者不为空,就返回表达式,如果调用者为null,就返回null
val listWithNulls : List<String?> = listof("A",null)
for(item in listWithNulls){
item?.let{println(it)}
}
-->如果只对非空值进行操作,安全调用符可以和let一起使用
val l = b?.length ?:-1 -->Elvis操作符(?:),如果?:左侧表达式非空,Elvis操作符就返回其左侧表达式,否则返回右侧表达式。
val l = b!!.length-->!!操作符,如果b为空,就会抛出一个NullPointException。
obj!!.javaClass.isInstance(ClassName::class.java)-->对比是否是某个类的类型
**************************************集合的细节*****************************************
listOf() 、mutabceListOf() 、setOf() 、mutableSetOf() 。 -->构建list、set集合
mapof(a ot b , c to d) -->非性能关键代码中创建map
java类型-->Kotlin类型
int[] -->kotlin.IntArray!
String[] --> kotlin.Array<(out)String>!
**************************************类与对象*****************************************
- 匿名内部类
**************************************字节运算符*****************************************
只可以用在Int和Long类型-->好吧,是在下输了,那byte怎么办,肿么办...
- shl(bits)-->有符号左移(java的<<)
2.shr(bits)-->有符号右移(java的>>)
3.ushr(bits)-->无符号右移(java的>>>)
4.and(bits)-->位与
5.or(bits)-->位或
6.xor(bits)-->位异或
7.inv()-->位非
**************************************重载方法*****************************************
在方法前加上@JvmOverloads注释,否则相同的方法只会生成带有所有参数的一个方法。