作者:Antonio Leiva

时间:Apr 4, 2017

原文链接:https://antonioleiva.com/nullity-kotlin/

关于Kotlin最重要的部分之一:无效处理,我花了很长时间完成写一篇文章。

东尼·霍尔(Tony Hoare)“空(null)”概念的创作者,自称“十亿美元的错误”。在你编写Java代码是,null是最容易出错的指针。

如果你在观察Bug管理器,我确信你见到的NullPointerException错误要超过90%。

多亏Kotlin,你将工作在更加安全的环境中(即使是用Java库),它是这些问题尽量减少。

Kotlin的Null

除非你设定,Kotlin不存在Null。

也就是说,没有变量缺省值能够被设置成null。记住,在Kotlin中所有类型都是对象。

因此,不能编译:

 val x: Int = null

如果要变量接受Null,你必须为类型加上问号(?):

 val x: Int? = null

编译时检查

然而,从这点来说,编译器强制你在对该变量做任何事情之前检查变量是否为null。这确保NullPointerException不会发生。

例如:

 val y = x.toDouble()

如果你不先检查是否为null,则不能编译,必须这样:

 if (x != null) {
val y = x.toDouble()
}

安全访问表达

有一个更容易的方法表示前面的例子,在调用方法时,在“.”之前加个问号(?)。

如果变量不是null,它将执行操作。否则,它不做任何事情:

 val y = x?.toDouble()

在这种情况下,如果 x 是 null,那么表达式将返回null。所以,y将是Double?类型。

Elvis操作符

但是,如果我们不希望有一个可以为空变量作为操作结果怎么办?在这种情况下,Elvis操作符允许我们返回一个值:

 val y = x?.toDouble() ?: 0.0

这行代码等效:

 val y = if (x != null) {
x.toDouble()
} else {
0.0
}

注意:

如你所见,Kotlin中大多数语句都转化为表达式。例如,你能够将if的结果赋值给变量。

避免null检查

如果你确信变量不可能为null,可以用操作符(!!)可以避免null检查。

以我看,极少有情况需要这个操作符。总是有更好的解决方案。

但是,你能够这样做:

 val x: Int? = null
val y = x!!.toDouble()

这能够编译,并且产生NullPointerException。

这就是为什么我说:要非常小心使用这个操作符。

Java支持

当我们使用Java库时,我们可能会发现自己要面对不同的null检查情况。

库恰当的注解

如果在Java和Android中,适当地使用@Nullable和@NotNull注解,Kotlin能够与其很好的对接,并且,能够指出变量什么时候是null,什么时候不是

Android框架的许多部分已经正确的注解了,所以这是与Kotlin配合使用的巨大优势。

库没有注解

然而,如果库没有注解,类型将以特殊操作符(单一!)标注,这就意味着这是在我们这边决定一个参数或返回值是否接受null

如果我们阅读源代码,最好检查代码以决定是否允许使用null。

Android没有注解的例子是RecyclerView支持库。当你创建一个适配器和生成方法时,缺省是为类型加询问。

但是,如果您查看源代码,会发现在需要覆盖的方法中,没有任何东西能够是null。

结论

对所有Java开发者,NullPointerException是个噩梦,大多数情况,这表示你的代码发生错误了。

这在Kotlin中,很容易地将这类错误几乎减少到零,即使使用Java框架和库。

只有这样,就可避免不必要的长时间的调试工作,而且可以让代码更加稳定。

如果你要进一步的学习所有这些,且能够流利创建你自己的Android APP,我建议你找这本免费书学习怎样创建你的第一个项目,或直接获取这本书,学习怎样从头开始创建一个完整的APP。

---恢复内容结束---

再见NullPointerException。在Kotlin里null的处理(KAD 19)的更多相关文章

  1. 优雅的运用 Kotlin 的 null safety 特性,而不要简单的直接用 !!双感叹号

    对于 Null 的检查是 Kotlin 的特点之一.强制你在编码过程中考虑变量是否可为 null,因此可以避免很多在 Java 中隐藏的 NullPointerException. 但是,当你用插件直 ...

  2. java里null强转为某个类会报错吗?

    1.定义一个User类如下: /** * @author lizhibiao * @date 2018/11/27 17:21 */public class User{ private String ...

  3. kotlin之null值安全性

    var a: String =null // 编译错误 var a: String? =null // 编译通过 要允许null值, 需要将变量声明为可为null的字符串类型:String? fun ...

  4. MySQL里null与空值的辨析

    CREATE TABLE `test` ( `col1` VARCHAR( 10 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL , `co ...

  5. 用Kotlin实现Android定制视图(KAD 06)

    作者:Antonio Leiva 时间:Dec 27, 2016 原文链接:https://antonioleiva.com/custom-views-android-kotlin/ 在我们阅读有关c ...

  6. 在Kotlin编写RecyclerView适配器(KAD 16)

    作者:Antonio Leiva 时间:Mar 14, 2017 原文链接:https://antonioleiva.com/recyclerview-adapter-kotlin/ 通过创建Recy ...

  7. 尝试Java,从入门到Kotlin(下)

    上篇已提(tu)到(cao)Java中的各种坑.习惯了C#的各种特性和语法糖后,再转到Java感觉比较别扭.最后本着反正Java也不是很熟悉,干脆再折腾折腾其他语言的破罐子破摔的心态,逛了一圈JVM语 ...

  8. SQL - where条件里的!=会过滤值为null的数据

    !=会过滤值为null的数据 在测试数据时忽然发现,使用如下的SQL是无法查询到对应column为null的数据的: select * from test where name != 'Lewis'; ...

  9. Kotlin, Android的Swift

    Kotlin, Android的Swift 苹果已经用Swift代替Objective-C,一种古老的语言,来进行iOS的开发了.明显Android开发也有这个趋势. 虽然现在已经可以选择Scala或 ...

随机推荐

  1. linux mariadb

    https://www.linuxidc.com/Linux/2016-03/128880.htm -- sql 导入 接着输入你所导入到Centos下的数据库文Student.sql文件的位置例如: ...

  2. jmeter 填写URL链接后 不能有多余的空格。

  3. PL/SQL 用户自定义子类型

    子类型具有与其基本类型相同的操作,但只有基本类型有效值的子集. 例如,PL/SQL预先定义子类型CHARACTER和INTEGER,如下所示: SUBTYPE CHARACTER IS CHAR; S ...

  4. etcd部署简单说明

    etcd是一个K/V分布式存储,每个节点都保存完成的一份数据.有点类似redis.但是etcd不是数据库. 1.先说废话.之所以会用etcd,并不是实际项目需要,而是前面自己写的上传的DBCacheS ...

  5. Python3集成安装xadmin

    Python3集成安装xadmin1:创建虚拟环境C:\Users\Adminstrator>mkvirtualenv -p C:\Python34\python.exe MyDjango如果提 ...

  6. JDBC编程:获取数据库连接

    JDBC(Java Database Connectivity),即Java数据库连接.通过JDBC编程,可以使Java应用程序和数据库进行交互. JDBC驱动的方式有很多种,我们常用的驱动方式为:本 ...

  7. chromium之non_thread_safe

    先看看介绍 // A helper class used to help verify that methods of a class are // called from the same thre ...

  8. 使用Python读取Dbf文件

    DBF:一种特殊的文件格式!表示数据库文件,Foxbase,Dbase,Visual FoxPro等数据库处理系统所产生的数据库文件! DBF 数据库是常用的桌面型数据库,它曾经被各企业.事业单位广泛 ...

  9. Mysql读写分离,主从同步实现

    随着用户量的增多,数据库操作往往会成为一个系统的瓶颈所在,因此我们可以通过实现数据库的读写分离来提高系统的性能. 通过设置主从数据库实现读写分离,主库负责“写”操作,从库负责“读”操作,根据压力情况, ...

  10. MAC系统如何显示隐藏文件解决方法

    苹果Mac OS 操作系统下,隐藏文件默认为隐藏状态,隐藏文件是否显示有多种方法可以设置. 方法一: 打开终端,输入命令行 1.显示Mac隐藏文件的命令: defaults write com.app ...