干了十年 Android 开发,为什么我再也不想继续了

本文最初发布于LevelUpCoding博客。

在这篇文章中,我将谈谈为什么我在这个行业工作了近十年之后,永远地离开了Android开发。在开始之前,让我简单介绍下自己在这个领域的职业生涯。

美好时光

我从2013年开始接触Android开发,在当时还是热门的新事物。AsyncTasks还是标准,还有OttoEventBus和其他令人讨厌的东西。我见证了架构演进的过程,从MVC到MVP/MVI,然后转向MVVM,最后是MVVM和MVI的混合。

我记得,当RxJava出现时,一切都突然变成了反应性的,变成了流。我记得,l33tAndroidDevs(HiJakeWharton)在谈论那个新出现的黑马Kotlin。我记得,Kotlin兴起并接管了Android行业。我记得,Coroutines出现了,并且起初被认为是“RxJava”的杀手(嘿,你现在可以用同步方式编写所有异步代码了!不需要流了!)。这个理念很吸引人,但很快就被证明,那仅仅是一个好主意而已,因此,像Channels这样的底层异步原语成为Kotlin的Rx-Way。不过事实证明,很多使用Channels的人都是自断双臂。不得已,精益冷流(ColdStreams)和热流(HotStreams)的概念被重新引入,请允许我向你介绍:StateFlows和SharedFlows,最后,我们得到了一个轻量级的、支持Coroutines的Kotlin版RxJava2。

我记得,我和同事David围绕状态和事件展开的所有有趣的对话,到底什么是状态,什么是事件?事件对状态有什么作用,反之亦然?我记得,在Dagger2被Koin和DaggerHilt取代之前的几年,我熬夜学习Dagger2。我还记得,第一次阅读UncleBob的《架构整洁之道》,这是我在Android开发生涯中最开阔眼界的时刻之一。现在,我能够设计和编写几乎所有应用程序,而不需要考虑MVVM/MVP/MVC或任何其他特定于平台的细节。我知道为什么测试很重要,我尝试了TDD,对它是又爱又恨,我还学习了DDD和BDD。

我的火车到达终点站了吗?

(我选择这个副标题是因为我现在正在从瑞士到德国的火车上写这篇文章。)

后来,我加入了保时捷和IBM等大企业的领导团队,这是一段很好的旅程,经过6-7年的经验积累,我达到了目标。我曾开发过复杂的应用程序,涉及大量的E2E加密、传感器通信、NFC芯片、BLEBeacon、高流量聊天应用,还有非常有名的待办事项应用,等等。

大约6年后,我开始以首席Android开发人员的身份参与项目。我学会了识别所参与的大多数项目的核心技术问题(架构和团队成员对某些模式有不同的理解),我还学会了如何指导团队解决这些问题,以及如何成功地完成项目。对我而言,现在新东西仅仅是学习新的API变化/框架,目的是解决我们已经解决了很多年的问题,只是新的框架/API做了更好的处理(不用再手动处理生命周期、FragmentTransaction、XML布局等)。

我以前的后端经验

很幸运,在过去的4-5年里,我在客户项目中从事后端工作(根据要求)。我花了很多时间去了解后端开发的来龙去脉,编写并发代码,创建分布式系统,纵向和横向扩展,处理分布式事务,编写可配置的代码,在不同阶段的环境表现出预期的效果。我研究了不同类型的数据库(图、关系、文档),以及什么样的数据应该使用什么样的数据库,我学习了Docker和K8s,我用Go重构JavaEE系统。看着由Go编译出来的二进制文件,它的内存使用率和几乎为零的内存占用,我明白了为什么Go如此令人惊叹。作为后端开发人员,我所解决的问题与我在Android开发中遇到的挑战无法相提并论(我很快就会讲到),作为后端开发者,我所解决的问题比在Android上推敲像素影响更大、更深远。

Android真的就那样吗?

作为一名经验丰富的Android开发人员,我只适合Android职位。我所有的技能都是为了能开发出可维护的、整洁的、能在Android平台上正常工作的代码。有些代码会被垃圾收集器如期杀死,而有些代码能在垃圾收集器中存活下来,因为它本该如此。如果Android很快消失了怎么办?看着像Flutter这样优秀的技术,人们已经用它开发出了一些很棒的应用,我不会再把任何新项目作为单独的原生iOS和原生Android应用来启动。老实说,你的Android技能对于大多数公司的首席/资深软件工程师职位来说价值并不高。

Android开发日薄西山

我成功地完成了自己的最后一个项目。现在是时候做一些改变了。我不想再花几天的时间讨论CardView的边框或反复出现的毫无意义的问题,比如是使用单选按钮还是复选框。我不想再为了更好地处理Android生命周期或导航而学习新的Android库,然后在未来12个多月内看它们再次被替换,在过去的10年里,这种事我已经做过好多次了。开发人员一代接一代,每一代中都会有人觉得自己有权力编写一个新的库来处理UI状态,或者编写一个新的导航库。测试?不,没有。可悲的是,有很多开发者会使用这些库。Android开发正慢慢被吞噬Web开发的混乱所吞噬(你试过安装create-react-app吗?你会下载数以千计的库,包括一些易受攻击的库)。

幸运的是,在过去几年里,我曾在几个项目中从事后端工作,这使我有机会过渡到后端开发,彻底离开安卓,专注于开发每秒处理数十万用户请求的系统,这对我来说非常有吸引力。现在,路线图上有一些我作为Android开发者不了解的新东西:获得K8s认证,掌握多个云,深入学习特定数据库,深入理解DevOps。我感觉,编程的神秘性再次激发了我,有复杂的工程问题需要处理,这让人兴奋。

让人难过的是,对于一个纯粹的Android开发者来说,架构师或首席/资深工程师的道路是封闭的。纯粹的Android开发人员根本不具备履行这些职位所需的技能。对我来说,这是一次很棒的旅程,但我再也不会以Android开发人员的身份参与项目了。

英文原文:

版权声明:本站所有作品(图文、音视频)均由用户自行上传分享,仅供网友学习交流,不声明或保证其内容的正确性,如发现本站有涉嫌抄袭侵权/违法违规的内容。请举报,一经查实,本站将立刻删除。

相关推荐