-
简洁性
这里我以最简单的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这类空安全语言默认对象和字段不能为空,如果我们非要让一个字段或对象为空那么必须使用安全调用操作符(?)来指定。
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.<layout> .*
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)
}