Kotlin stdlib使您的生活更轻松

恕我直言,Kotlin并不是主要的杀手级功能-虽然可以肯定地将扩展方法和属性归类,但是可以带来很多深远的影响。 它们大多数不是语言内置的,而是作为Kotlin标准库的一部分提供的功能。 在本文中,我想介绍其中的一小部分,并描述如何使用它们来改进代码。<!-more-→

去做()

在新的代码库中具有//TODO注释是很常见的。 对于我们大多数开发人员而言,这甚至可能是一种反思。 当流程进入时,不要因为缺乏规范而停下来,而是写下一个提醒以备稍后使用。 以后意味着什么。 即使是IDE,也很乐意生成带有此类注释的代码。

funcomputeCustomerNumber(customer:Customer):String{
    // TODO Not specified as of November 27th
}

但是,在运行实际代码时不会发生任何问题。 什么都没有发生,没有什么真正提醒我们应该实施这一部分。 当然,某些代码分析工具可能会发现它,但是可能已经为时已晚。 并且它要求该工具实际运行。

Kotlin提供了TODO()函数,该函数在调用时实际上会引发异常。 这样,即使运行一个简单的单元测试,也会强行将您指向一个事实,那就是那里有事要做。

funcomputeCustomerNumber(customer:Customer):String{
    TODO("Not specified as of November 27th")
}

应用()

根据API的具体细节,构造一些对象可能很繁琐,并且涉及很多细节。 为了隐藏这些细节,当前的共识通常是从中创建一种方法。 这是为Vaadin Web框架创建组合框组件的代码段:

funcreateCountriesCombo():ComboBox<String>{
    valcountries=ComboBox<String>("Countries")
    countries.setItems("Switzerland","France","Germany","Austria")
    countries.isEmptySelectionAllowed=false
    countries.placeholder="Choose your country"
    countries.addValueChangeListener{
        valcountry=countries.value
        bus.post(CountryChangeEvent(country))
    }
    returncountries
}

即使这样,根据要设置的属性的数量,也很容易迷失细节。 apply()是一个简单的函数,定义为:

fun<T>T.apply(block:T.()->Unit):T{block();returnthis}

这意味着可以在任何类型T上调用此函数,并且它的唯一参数是lambda接收器,该接收器不返回任何内容。 至于任何拉姆达接收机, this内部拉姆达指函数被调用的对象。 这使我们可以将以上代码片段重构为以下内容:

funcreateCountriesCombo():ComboBox<String>{
valcountries=ComboBox<String>("Country").apply{
        setItems("Switzerland","France","Germany","Austria")
        isEmptySelectionAllowed=false
        placeholder="Choose your country"
        addValueChangeListener{
            bus.post(CountryChangeEvent(value))
        }
    }
}

更好的是,现在可以轻松地重构代码片段以利用表达式主体:

funcreateCountriesCombo()=ComboBox<String>("Country").apply{
    setItems("Switzerland","France","Germany","Austria")
    isEmptySelectionAllowed=false
    placeholder="Choose your country"
    addValueChangeListener{
        bus.post(CountryChangeEvent(value))
    }
}

锦上添花,用任何有价值的IDE进行折叠,都可以用来显示概览,而展开可以显示细节。

IDE展开的套用功能

IDE折叠的应用功能

采用()

在Java 7之前,必须在finally块中显式完成关闭连接的操作:

Connectionconn=getConnection();
try{
    // Do stuff with the connection
}finally{
    if(conn!=null){
        conn.close();
    }
}

Java 7添加了try-with-resource语法 。 例如,上一个代码段可以重构为以下代码段:

try(Connectionconn=getConnection()){
    // Do stuff with the connection
}

使用资源进行尝试的语法大大简化了代码。 但是,它是语言语法的一部分,因此具有很多隐含性:

  • 资源语句中的类型必须实现AutoCloseable
  • 同一条语句中可以打开多个资源。 在这种情况下,它们以打开时的相反顺序关闭。
  • 如果在try块中以及在关闭资源期间引发了异常,则该资源将被抑制并设置为主要异常。

Kotlin对应项通过use函数处理,其签名为:

fun<T:Closeable,R>T.use(block:(T)->R):R

不涉及黑魔法。 这是一个简单的功能,其源代码可在线获得

结论

这些仅是可用示例。 通常,语言的语法可以在21天(甚至更少)内学习。 但是,了解该API需要花费更多时间。

Kotlin不太关注语法,而更关注API。

翻译自: https://blog.frankel.ch/make-life-easier-kotlin-stdlib/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值