Nicolas Fränkel 是一名资深程序员,领有近二十年的Java开发经验。他在几年前开始学习Kotlin,在此之后,每当他再应用Java时,总会思考为什么本人写的Java代码,看起来不如Kotlin那么优雅,并且发现Java短少一些能够晋升代码可读性、表现力和可维护性的性能。对此,Nicolas Fränkel以“Kotlin开发者”身份总结了他认为Java短少的个性:
·不可变援用 (Immutable References)
·空平安 (Null Safety)
·扩大函数 (Extension Function)
·具体化的泛型 (Reified Generics)
1.不可变援用 (Immutable References)
尽管Java容许开发者定义不可变援用,但这不是强制性的。因为默认状况下,援用是可变的,但大多数Java代码并没有利用不可变援用。
Kotlin不会让开发者抉择:每个属性和局部变量都须要定义为a val或a var。另外,Kotlin不反对重新分配办法参数。
2.空平安(Null Safety)
在Java中,无奈晓得变量是否为null。基于此,Java 8引入了Optional类型。从Java 8开始,返回Optional意味着根底值能够是null;返回另一种类型则意味着不是。
Optional

显然,有些库专一于特定的IDE。此外,库之间简直不兼容。而且可供使用的库太多了,以至于常常有人会询问该应用哪一个。
最初,在Java中应用可空性库是可选的。而Kotlin则要求每种类型都能够为空或不可为空。
val nonNullable: String = computeNonNullableString()val nullable: String? = computeNullableString()
3.扩大函数 (Extension Function)
对于以下这段 Java 代码:
class StringUtils {
private StringUtils() {}

static String capitalize(String string) {                   return string.substring(0, 1).toUpperCase()        + string.substring(1);                           }

}String string = randomString();
String capitalizedString = StringUtils.capitalize(string);
可应用Kotlin的扩大函数个性重写为:
fun String.capitalize2(): String {
return substring(0, 1).uppercase() + substring(1);
}val string = randomString()val capitalizedString = string.capitalize2()
Kotlin提供了应用新性能扩大类或接口的能力,而无需从类继承或应用Decorator等设计模式。开发者能够通过名为 extensions 的非凡申明来实现它。
例如,开发者能够为无奈批改的第三方库中的类或接口编写新函数。这些函数能够以常见的形式进行调用,就如同它们是原始类的办法一样。这种机制称为扩大函数。
4.具体化的泛型 (Reified Generics)
举个例子,如何从值的容器中获取类型化的值。上面是Spring的示例:
org/springframework/beans/factory/BeanFactory.java
public interface BeanFactory {
<T> T getBean(Class<T> requiredType);
}
开发者增加了一个Class<T>参数,以便可能晓得办法体中的类型。但如果Java曾经具体化了泛型,那就能够这样写:
public interface BeanFactory {

<T> T getBean();

}
如果 Kotlin 曾经具体化了泛型:
interface BeanFactory { fun <T> getBean(): T
}
并调用函数:
val factory = getBeanFactory()val anyBean = getBean<Any>()

Nicolas Fränkel示意,Kotlin已成为他在JVM上的首选编程语言,至于Java,只有在必要的时候才会应用。更多时候,他们更偏向于应用基于Java的更高效的专业化低代码平台,以防止大量繁琐的底层代码带来的工作量。