- funcomputeCustomerNumber(customer:Customer):String{
- // TODO Not specified as of November 27th
- }
赞
踩
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
不涉及黑魔法。 这是一个简单的功能,其源代码可在线获得 。
翻译自: https://blog.frankel.ch/make-life-easier-kotlin-stdlib/
kotlin-stdlib
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。