Kotlin项目练习记录

Kotlin项目练习记录

替换findviewbyid

app/app.gradle 下导入apply plugin: ‘kotlin-android-extensions’插件,才能直接使用xml里面的定义的id(替代掉findviewbyid)

跳转activity

val intent = Intent()
intent.setClass(this,MainActivity::class.java)
startActivity(intent)

或者封装一下:


inline fun  Activity.newIntent() {
    val intent = Intent(this, T::class.java)
    startActivity(intent)
}

null的判断变得简单,从此不用担心空指针了

//可以是null
var mPresenter: String? =null
//如果发现是null,则不要去调用方法
mPresenter?.length()
//这就可能报错npe了
mPresenter!!.length()

网络请求单例模式

单例在Kotlin有更简单的方法实现,只要在 package 级别创建一个 object 即可

//重要修饰符 
companion object{
        @Volatile
        var instance: RetrofitClient? = null

        fun getInstance(context: Context,baseUrl: String) : RetrofitClient {
            if (instance == null) {
                synchronized(RetrofitClient::class) {
                    if (instance == null) {
                        instance = RetrofitClient(context,baseUrl)
                    }
                }
            }
            return instance!!
        }

    }

修饰符区别 object class, data class , class

data class 比较好理解 就是对应这java中的实体类,该类不包含方法,并且默认已经帮你生成了get, set ,toString等常用方法

class 就是普通的类 这里面如果使用静态成员 则需要用到companion object

object 解决kotlin中没有静态成员问题,用object修饰类的时候,里面的成员默认都是静态成员

//静态常量
companion object {
        var MSG_IMAGE_LOADED = 101
    }

lambda表达式

一开始觉得lambda很高级完全看不懂,其实很简单的就是把接口名、方法名和参数类型省掉不写再加个->罢了,明白这点了很好理解。

// 无参数无返回值
Thread(Runnable {
    sleep(1000)
}).start()
// 单参数不带返回值
view.setOnClickListener { v ->
    Log.e("tag", "${v.tag}")
}
// 多参数带返回值
view.setOnKeyListener(View.OnKeyListener { v, keyCode, event ->
    Log.e("tag", "keyCode$keyCode, ${event.keyCode}")
    if (event.keyCode == KeyEvent.KEYCODE_BACK)
        return@OnKeyListener true
    false
})

实现了Java中try-with-resource语句的功能

你可能感兴趣的:(Kotlin)