Koltin值得学习的原因

  • 简洁性

这里我以最简单的POJO为例

public class User {

    private String  name;
    private int age;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }
}

这是我用Java写的一个POJO,定义了一个user类,有两个属性name、age,那么用Kotlin是怎么写的呢?如下:

class User {

    var name: String? = null
    var age: Int = 0
}

Kotlin会自动生成所有的属性和它们的访问器,下列是带参数的构造器书写

class User {

    var name: String? = null
    var age: Int = 0

    constructor(name:String){
        this.name=name
    }

    constructor(name:String,age:Int){
        this.name=name
        this.age=age
    }

}

那么如何创建一个user对象呢?如下:

var myuser=User("tracy",18)

对比一下Java和Kotlin的编程,Kotlin代码的简洁性显而易见。

  • 空安全

当我们用Java写代码时,我们如果不想出现NullPointerException,我们需要在使用它之前每次去判断是否为空。而Kotlin这类空安全语言默认对象和字段不能为空,如果我们非要让一个字段或对象为空那么必须使用安全调用操作符(?)来指定。


image.png
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        val user : User?= null
        toast(user.name)
       
    }
    
   fun toast(text:String?){
        Toast.makeText(this,text,Toast.LENGTH_SHORT)
    }

这样直接调用是会编译报错的,因为user可能为空,下列有两种方法可以处理
方法一:直接加个非空判断

        var  user : User?= null
        if(user != null){
            toast(user.name) 
        }

方法二:使用安全符(?)

        var user: User? = null
        toast (user?.name)

当user值为空时,我们还可以设置个默认值

        var user: User? = null
        toast (user?.name?:"tracy")
  • 易扩展性

Kotlin允许我们对任何类添加方法,包括系统级的类,自定义类等等,比如我想在Context类中添加一个toast方法。

  var contxt:Context?=null

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        contxt=this.contxt;
        contxt?.toast("my name is kotlin")
    }
    
    fun Context.toast(message:String){
        Toast.makeText(this,message,Toast.LENGTH_SHORT)
    }

这样所有使用 Context的地方都可以直接调用context.toast,如果扩展方法只写到当前类中,那么只在当前类生效

  • 函数式(Lambdas)

我这里以常用到的点击事件为例

    private View tv;

    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        tv=findViewById(R.id.tv);
        tv.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Toast.makeText(JMainActivity.this,"hello world",Toast.LENGTH_SHORT);
            }
        });
    }

如果用Kotlin编程,那么只需要一行代码即可解决

    private var tv: View? = null
    
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        tv = findViewById(R.id.tv)
        tv?.setOnClickListener({tv -> toast("Click")})
    }

    fun Context.toast(message:String){
        Toast.makeText(this,message, Toast.LENGTH_SHORT)
    }

有些时候我们并不需要用到tv参数

   tv?.setOnClickListener{toast("Click")}
  • Kotlin Android Extention

相信我们早已经厌烦了些一堆的findViewById这样的代码,使用Kotlin我们可以直接用id绑定
首先应该导入布局,导入格式为import kotlinx.android.synthetic.main. .*

import kotlinx.android.synthetic.main.activity_main.*

class JMainActivity internal constructor() : Activity(){

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        tv?.setText("hello world");
        tv?.setOnClickListener{toast("Click")}
    }

    fun Context.toast(message:String){
        Toast.makeText(this,message, Toast.LENGTH_SHORT)
    }

你可能感兴趣的:(Koltin值得学习的原因)