天天看点

如何看待 Kotlin 成为 Android 官方支持开发语言?

如何看待 Kotlin 成为 Android 官方支持开发语言?

本文转载自“技术小黑屋”,原文《如何看待 kotlin 成为 android 官方支持开发语言?》。文章转载已获授权。

google io 2017宣布了 kotlin 会成为 android 官方开发语言。一时间朋友圈和android圈被各种刷屏。当然我也顺势而为发布了一篇的文章《为什么我要改用kotlin 》,着实狠狠地蹭了一波热度(尽管这样会被鄙视)。眼下android圈已经躁动了,甚至严重到如果对kotlin视而不见就显得自己不像一个合格的android程序员。

本文尝试从一个客观全面一点儿的角度来看待这件事情,尽力为大家提供一个比较理性的观点供参考。

关于 google 为什么会选择 kotlin,我认为有两方面的原因。

1.为了逐渐摆脱专利流氓oracle。从去年的转向openjdk,到现在的支持kotlin作为官方语言,某种意义是为了摆脱藉由9行代码敲诈获取天价赔偿的oracle。

2.选用kotlin,实至名归,这个荣誉它值得拥有。kotlin确实以其实用,高效赢得了海外很多公司和开发者的认可,比如square的jake大神一直在推kotlin。kotlin在国外至少有将近2年的应用生产环境的实践(非jetbrains内部实践应用)。在移动开发中,相比ios程序员,android程序员总是很幸运,因为我们有很多优秀好用的工具(android studio等),选用kotlin,则是google 为开发者提供高效的开发工具的一贯作风。

官方:工具支持(android studio 3.0附带kotlin),官方的宣传(教学视频,主题演讲等)

对于社区来说,kotlin版本的库和框架如雨后春笋般涌现

对于java,曾经借助android这场春风,着实让迟暮的它再度辉煌,现在和将来在android领域可谓是棋逢敌手,java的在android开发语言市场份额会降。但是这也并不一定是坏事,有竞争才能更好进步。

对于android 开发者,我们多了一种开发android的语言选择,那些对于之前由于前景不明朗却对kotlin跃跃欲试的人可以放心使用了。有了kotlin意味着开发效率应该会有所提升。

对于团队,这往往带来了一个选择的问题,use kotlin or not, that’s a question. 团队中总有人想要尝试kotlin,而另一些人则兴致不那么高。由于历史包袱,团队成员兴趣,对于已有项目采用kotlin和java长期并存是实际可行的方案。而新项目则应该鼓励使用kotlin,但具体还需要结合团队的能力和其他因素。

kotlin的有很多特点,比如简洁,安全实用,开发效率高和提升可读性,更好的函数式编程支持。

1.简洁,kotlin的代码确实比java更加简洁,比如类型推断,省去结尾的分号等等,然而这远不能成为我们改用kotlin的原因。

2.安全,这是kotlin的一个很重要的特性。kotlin是空指针安全的,jetbrains做了一件很聪明的事情,它们将运行时才能空指针的检测提前到了编译时,主要方式是增加了any?这种可为空的类型,使用kotlin之后,我们程序的空指针会得到明显的改善。

3.实用,高效率。kotlin的实用具体表现在

4.kotlin引入了lambda,streams api 和函数式编程支持。

5.可读性 从客观上,kotlin语法和特性上让代码更加具有描述性而已。但是不得不指出代码可读性主要依赖编写者的编码素质和能力。

对我个人而言,高阶函数和方法扩展这两个特点着实真心受用。方法扩展会让我有一种创造感,这是java种的util方法所无法比拟的。

这个很难说,因为这个世界上并不是一件事物好,就会必然得到广泛应用的。一件事物的推广开来靠的是一群人,但阻力也往往也来自一群人,只不过和前者不是相同人群。

从个人主观来看这个问题,我更加愿意看到这种现象发生。原因并不是因为我更喜欢kotlin,而是在于我更愿意看到事物在进步,在变得优秀,所以即便某一天kotlin被更加优秀的语言取代,我也是很欢迎的。

kotlin适用于多个平台,并没有对学习者做限制。任何有学习意愿的人都可以习得这门语言。

但是考虑到国内 kotlin 资源不够丰富,网络不够畅通等问题,所以导致了很多人变成了吃瓜群众进行观望。

然而,对于一个项目和团队来说,总需要有第一个人先来推进。而且这个推进过程并非顺利,这其中包括

上述推进 kotlin 观点部分参考自life is great and everything will be ok, kotlin is here (google i/o ‘17) 中 christina lee(pinterest software engineer,国外 kotlin 美女布道师之一)的分享内容。

虽然 kotlin 很优秀,但是推动在项目中推动 kotlin 应用并非易事,因为这对于新事物来说在正常不过了,就像明治维新一样看起来很光鲜,成功,但是它的变革进程并非顺利,先是血雨腥风的倒幕运动,再到明治六年爆发的标志武士时代结束的西南战争,经过数十年的努力才算取得成功。

因此关于哪些人适合率先应用 kotlin,我认为需要具备以下几点

目前想到了一些关于 kotlin 应用在项目中的一些顾虑。这些顾虑目前并非全面,但是提出来,希望大家可以规避和改善。

1.写出来的代码并不是 kotlin style。解决这个问题,还是需要多学习和思考

2.扩展方法的滥用,kotlin 的扩展方法很好,我们可以扩展很多方法,弥补framework的一些不完善,但是扩展时我们需要谨慎,一定要把合适的方法放到合适的类型上,不可为了简单增加不符合某些类不应该具备的职责。 具体需要最好以下两点

kotlin出来之后,听到了两种不同的声音:

出现以上两种不同的声音,不得不引起我们对于 android 程序员的核心竞争力的思考。那么到底什么才是 android 程序员的核心竞争力呢?

android程序员和其他程序员甚至其他职业并无二致,我认为这种竞争力表现在解决问题的能力。想要具备这种能力,极其依赖我们对问题和技术的准确认识和扎实的基础。

编程语言本质上还是工具,好的工具能带来更好的效果,但是如何运用好,将效率和质量提升到最高,则还是更主要的依赖于开发者的能力。

选用好的工具,更侧重夯实基础和加强对事物本质认识的能力,我想这样才能让我们的竞争力更强。

总结而言,kotlin是一个更好的工具,没有它,并不影响我们日常的 android 开发工作。但是我还是建议开发者和团队去尝试这种语言,抓住这个近在咫尺的小确幸。

事情的发展越来越显得不可控了,推介kotlin和不看好kotlin的人逐渐分化出来,更准确的说,甚至这件事已经快要演变成了从对事变成了对人。

kotlin 成为 android 官方语言的消息一出来,一下子出来了很多被当做投机蹭热点的kotlin推介者,当然还出现了一些看不惯这些做法的人,他们认为前者刻意拔高了kotlin。因而讨论越来越偏向从事情到人的方面。我想要说的是,就像商人追求利润,资本家攫取剩余价值那样,投机者蹭热点,以及招致他人批评,这都是正常的事情,但是我们不能让讨论脱离问题的本质,我们需要回归。

没错,kotlin是有很多很多的语法糖。有必要简单普及一下语法糖的概念(如下摘自维基百科)

由定义可知,语法糖的目的就是让代码更简单,更可读。

决定kotlin使用这么多语法糖的除了简洁,高效可读之外,还有一个原因,是因为kotlin编译生成的class文件是目标到jvm 6(基于jvm 6 是一种权衡后的结果),比如我们在kotlin中使用了lambda,它是不可能编译成invokedynamic指令的,因为那样会导致在jvm6上根本无法识别,所以经常通过翻译成内部类的形式来实现。

使用语法糖又能怎样,它的目的是好的,毕竟它真真实实减少了开发人员的代码量。

kotlin是一门实用语言,这是它的基因,它不是学术语言,它的目标是减轻开发者的负担。它很适合 android,因为大多数的 android 的程序员是做工程。

kotlin,是基于jvm的编程语言,但是基于jvm的编程语言并没有什么不好。(j)vm的出现无非也是一种平衡的结果。在牺牲部分执行效率的前提下,提供了一定的抽象,加快了开发者的效率。这种tradeoff其实更加有利于人的一侧,这也是编程语言发展的趋势和目标

kotlin 在国内推广应用的道路可谓是 漫漫而修远兮。因此更需要真正实践,去踩坑的人开始on board,去出产更多的真正能推动 kotlin 应用的文章,分享等这些有实质性意义的行动。

继续阅读