Kotlin 语言参考文档 中文版 Help

原生(Native)应用程序开发与跨平台(cross-platform)移动应用程序开发: 如何选择?

人们醒着的时间大量用在他们的移动设备上. 他们还 每天在移动应用程序上花费 4.8 小时, 因此移动平台对任何商业类型都非常具有吸引力.

移动 App 开发技术还在持续进化中, 每年都会出现新的技术和框架. 由于市场上存在许多解决方案, 因此经常会难以作出选择. 你可能已经听说过 "原生 vs 跨平台" 的长期争论.

在创建一个 App 之前有很多因素需要考虑, 例如开发成本, 时间, 以及 App 的功能. 如果你想要同时针对 Android 和 iOS 用户, 那么这些因素尤其重要. 对你的某个项目来说, 使用哪种移动开发策略才是最好的, 可能会很难决定. 为了帮助你在原生和跨平台 App 开发之间进行选择, 我们创建了一个列表, 包括值得注意的 6 个基本因素.

什么是原生移动 App 开发?

原生移动开发意思是说, 你针对某个移动操作系统来创建一个 App – 大多数情况下是 Android 或 iOS. 开发原生应用程序时, 开发者会使用特定的编程语言和工具. 例如, 你可以使用 Kotlin 或 Java创建一个原生 Android 应用程序, 或者使用 Objective-C 或 Swift 创建一个 iOS App.

下面是原生移动 App 的主要优势和不利点.

优势

不利点

高性能. 用来创建原生 App 使用的核心编程语言和 API 使得这些 App 快速而且反应灵敏.

高成本. 原生 App 开发需要 2 组独立的开发队伍, 分别具备不同的技能, 因此增加了开发过程的时间和成本.

用户体验直观. 移动开发工程师使用原生 SDK 来开发原生 App, 因此 UI 风格一致. 原生 App 的界面被设计得更加适应于在特定的平台, 因此它们感觉象与设备融合在一起的一部分, 而且提供更加直观的用户体验.

开发团队大. 管理很多专业人士组成的大团队可能会非常困难. 为一个项目工作的人越多, 为沟通和协作而耗费的精力就越多.

能够使用特定设备的全部功能. 针对特定操作系统创建的原生 App 能够直接访问设备的硬件, 例如摄像头, 麦克风, 以及 GPS 定位功能.

代码中的错误更多. 更多行数的代码意味着更多 bug 存在的风险.

在 Android 和 iOS App 中存在业务逻辑差异的风险. 使用原生 App 开发方案, 针对一个移动平台编写的代码无法在另一个平台上使用. 例如, 由于折扣计算方式的错误, Android 和 iOS App 可能对同一个商品显出不同的价格.

什么是跨平台 App 开发?

跨平台 App 开发, 也叫做多平台开发, 意思是说创建兼容多个操作系统的移动 App. 移动开发工程师能够在多个平台之间共用一部分, 甚至全部的源代码, 而不是为 iOS 和 Android 创建不同的应用程序. 通过这种方式, 应用程序在 iOS 和 Android 的工作结果是一样的.

现在已经有了很多用于 跨平台移动 App 开发 的开源框架. 其中最流行的一些是 Flutter, React Native, 以及 Kotlin Multiplatform Mobile. 下面是这种方式的主要优势和不利点.

优势

不利点

代码共用. 开发者可以创建单一的代码库, 不必为每个 OS 编写新代码.

性能问题. 有些开发者 认为多平台应用程序与原生 App 相比性能比较低.

开发更快速. 你不需要编写或测试更多代码, 因此可以帮助你加快开发速度.

难于使用移动设备的原生功能. 创建一个需要访问平台专有 API 的跨平台 App, 需要耗费更多精力.

低成本. 对于初创企业和预算有限的公司, 跨平台解决方案是一个很好的选择, 因为可以降低开发成本.

UI 一致性不佳. 使用跨平台开发框架使得你可以共用 UI, 应用程序的外观和使用体验可能不太象原生程序.

新的工作机会. 在你的产品技术栈中包含现代化的跨平台技术, 可以吸引新的人才加入你的团队. 很多开发者想要在工作中探索新的挑战, 所以新的技术和任务有助于提升开发者的热情, 并让他们在工作时感到更加有趣.

招聘困难. 与原生 App 开发者相比, 找到能够创建多平台 App 的专家可能更加困难. 例如, 撰写本文时, 我们在 Glassdoor 上找到大约 2,400 个 Android 开发者职位, 而 Flutter 开发者职位只有 348 个. 但是, 随着跨平台技术的持续进步, 并吸引更多的移动开发工程师, 这样的情况可能会发生改变.

共用业务逻辑. 由于这个方案使用单一的代码库, 你可以确保在不同的平台的应用程序逻辑是完全相同的.

这只是跨平台 App 开发的优势中很少的一部分. 关于它的优势, 以及在全球各大公司的使用场景, 请参见我们关于 跨平台移动开发 的文章. 关于这个方案的问题 – 我们在下面的章节中进行讨论.

关于跨平台 App 开发的一些常见的误解

跨平台技术一直在持续演进. 有些跨平台开发框架, 例如 Kotlin Multiplatform Mobile 提供了构建跨平台和原生 App 两种方案的优势, 解决了跨平台方案的一些常见限制.

1. 跨平台 App 的性能低于原生 App.

性能低下长期被认为是多平台应用程序的主要劣势. 但是, 你的产品的性能和质量 很大程度上依赖于你用来构建 App 的工具. 最新的跨平台框架提供了开发出类似于原生程序一样的用户体验的 App 所需要的所有工具.

通过使用不同的编译器后端, Kotlin 代码被编译为平台格式 – 在 Android 平台是 JVM 字节码, 在 iOS 平台是原生二进制代码. 因此, 你的共用代码的性能, 和你使用原生代码编写它们是一样的.

2. 跨平台框架不安全.

有一个常见的误解是, 原生 App 更加安全更加可靠. 但是, 现代化的跨平台开发工具可以帮助开发者创建安全的 App, 提供可靠的数据保护. 移动开发工程师只需要 添加额外的指标来提升他们的 App 的安全性.

3. 跨平台 App 不能访问移动设备的全部原生功能.

的确, 并不是所有的跨平台框架都能允许你创建 App 来访问设备的全部功能. 但是, 有些现代化的多平台框架能够帮助你解决这个问题. 例如, Kotlin Multiplatform Mobile 可以很容易的访问 Android 和 iOS SDK. 它提供了一个 Kotlin 预期声明与实际声明(expected and actual declarations) 机制, 可以帮助你访问设备的功能特性.

4. 管理跨平台项目很困难.

实际上, 恰恰相反. 跨平台解决方案能够帮助你更加有效的管理资源. 你的开发团队可以学习如何编写和复用共用的代码. Android 和 iOS 开发者通过互相沟通和分享知识, 可以达到很高的效率和高度的信息透明.

帮助你在跨平台 App 开发和原生方案之间作出选择的 6 个关键因素

下面, 我们来看看你为移动 App 开发选择原生和跨平台解决方案时需要考虑的一些重要因素.

1. 你未来的 App 的类型和目的

第一步应该是理解你要创建什么样的 App, 包括它的功能和目的. 一个带有很多功能的复杂的应用程序需要很多编程工作, 尤其是如果它是一个全新的 App、没有太多现成的模板可以借鉴.

你的 App 的用户界面有多重要? 你想要非常漂亮的视觉效果吗, 或者 UI 并不重要? 它是否需要任何特定的硬件功能, 是否需要访问摄像头和 GPS 定位功能? 你需要确保你选择的移动开发策略提供了必要的工具来构建你需要的 App, 而且提供了很好的用户体验.

2. 你的团队在编程语言和工具方面的经验

你团队中的开发者需要具有足够的经验和专业技能来使用某个特定的框架. 需要仔细考虑开发工具需要什么样的编程技能和编程语言.

例如, 开发者需要懂得 Objective-C 或 Swift 才能创建 iOS 的原生 App, 需要懂得 Kotlin 或 Java 才能创建 Android 的原生 App. 跨平台框架 Flutter 需要懂得 Dart 知识. 如果你使用 Kotlin Multiplatform Mobile, 对 iOS 开发者来说 Kotlin 语法是很容易学习的, 因为它遵循与 Swift 相似的概念.

3. 各种技术在未来是否能够长期存在

选择不同的方案和框架时, 你需要确信平台供应商能够在未来长期支持它. 你可以挖掘供应商的细节, 他们的开发社区规模, 被全球各大公司采用的程度. 例如, Kotlin Multiplatform Mobile 的开发者是 JetBrains, Flutter 的开发者是 Google, React Native 的开发者是 Facebook.

4. 开发成本和你的预算

上面提到过, 不同的移动开发解决方案和工具会带来不同的开支. 根据你的预算灵活度, 你可以为你的项目选择适当的解决方案.

5. 业内采用的广泛度

你总是能够找到技术社区的其他专家们对各种不同方案的意见. Reddit, StackOverflow, 以及 Google Trends 是几个不错的消息源. 请看看以下两个词语的搜索趋势: "原生移动开发" vs "跨平台移动开发". 很多用户仍然对学习原生 App 开发感兴趣, 但似乎跨平台方案正在获得更多关注.

原生移动开发的 Google 搜索趋势
跨平台移动开发的 Google 搜索趋势

如果一种技术被专业人士广泛使用, 它会拥有一个很强的生态环境, 大量的库, 以及技术社区的最佳实践, 这些都可以让你的开发工作更加快速.

6. 流行度与学习资源

如果你在考虑试用跨平台 App 开发, 你需要考虑的一个因素是, 找到各个多平台框架的学习资料的难易程度. 请查看它们的官方文档, 书籍, 以及课程. 请确认它们提供了带有长期计划的 产品路线图.

什么情况下你应该选择跨平台 App 开发?

在针对 Android 和 iOS 构建应用程序时, 为移动 App 开发的跨平台解决方案可以节省你的时间和工作.

简单的说, 对于下面的情况, 你应该选择跨平台解决方案:

  • 你需要创建一个同时运行于 Android 和 iOS 的 App.

  • 你想要节约开发时间.

  • 你想要对 App 的业务逻辑只保持单一的代码库, 同时又能够完全控制它们的 UI 元素. 并不是所有的跨平台框架都允许你实现这样的功能, 但是有一些框架, 例如 Kotlin Multiplatform Mobile, 提供了这样的能力.

  • 你热切希望采用持续演进中的现代化技术.

什么情况下你应该选择跨平台原生 App 开发?

对少数集中情况, 选择原生移动开发会更加合适. 对于下面的情况, 你应该选择这个方案:

  • 你的 App 只针对某一种用户 – Android 或 iOS.

  • 用户界面对你的应用程序非常重要. 但是, 即使你采用原生方案, 你也可以尝试使用多平台移动 App 开发方案, 它可以允许你对你的项目共用 App 的业务逻辑, 但不共用 UI.

  • 你的团队拥有极高技能的 Android 和 iOS 开发者, 但你没有时间来学习新的技术.

结束语

请关注上面介绍的各种因素, 你的项目的目标, 以及最终用户. 无论你喜欢原生开发还是跨平台开发, 都取决于你独特的需求. 每个解决方案都有它的长处, 也有它的弱点.

无论如何, 需要关注技术社区正在发生什么事. 知道最新的移动开发趋势, 可以帮助你为你的项目作出最好的选择.

最终更新: 2024/10/17