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值得加入,可以使用折叠显示概览,然后展开以显示细节。
用()
在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/
kotlin-stdlib