当前位置:网站首页 > Flutter跨平台开发 > 正文

Android:手把手带你入门跨平台UI开发框架Flutter

特别注意:
  • JIT 和 AOT指的是程序运行方式,和编程语言并非强关联的。
  • 有些语言可以以JIT方式 & AOT方式一起运行,如Java,它可在第一次执行时编译成中间字节码、然后在之后执行时可以直接执行字节码
  • 通常区分是否为AOT的标准就是看代码在执行之前是否需要编译,只要需要编译,无论其编译产物是字节码还是机器码,都属于AOT
Dart语言的特点

Dart语言具备开发效率高、高性能 & 类型安全的特点

具体如下:

3. 原理解析
3.1 框架结构

Flutter框架主要分为两层:FrameWork层、Engine层,如下图所示:

说明:开发时,主要基于Framework层;运行时,则是运行在 Engine上。每层的具体介绍如下:

3.2 原理概述

开发时,主要基于Framework层;运行时,则是运行在 Engine上

Engine是Flutter的独立虚拟机,由它适配 & 提供跨平台支持;因为其存在,Flutter不使用移动端系统的原生控件, 而是使用自己 Engine 来绘制 Widget (Flutter的显示单元);Dart 代码是通过 AOT 编译为平台的原生代码,所以 Flutter可直接与平台通信,不需要JS引擎的桥接。

同时 Flutter 唯一要求系统提供的是 canvas,以实现UI的绘制。

编译时,具体如下:

3.3 关于widget

Flutter理念:“一切皆为Widget”,Widget是Flutter应用程序用户界面的基本构建块,具备以下特点:

  • 属于具有一致性的统一对象模型,与其他将视图、控制器、布局和其他属性分离的框架不同。更新widget时更加高效
  • 不可变的,仅支持一帧,且每一帧上不会直接更新,要更新而必须使用Widget的状态。无状态和有状态Widget 的核心特性相同,每一帧都会重新构建;
  • 有一个State对象,用于跨帧存储状态数据 & 恢复
4. 特点

Flutter具备跨平台、开发效率高 & 高性能的特点

具体说明如下:

4.1 跨平台 & 开发效率高

Flutter通过使用上述所述的自身渲染引擎、原理框架 & Widget运行,使用一套代码即可同时构建iOS和Android应用,从而实现跨平台的特性,最终提高开发的效率

4.2 高性能
  • 原因1:通过其自带的高性能渲染引擎进行渲染
  • 原因2:Dart语言本身的语言特性
  • 原因3:编译过程特点,具体如下:

5. 对比

跨平台开发的本质是为了:增加代码复用、减少不同平台差异适配的工作量 & 提高开发效率。

目前主流的跨平台开发框架有:React-Native、Weex和本文提及的Flutter。下面,我先简单介绍React-Native和Weex,再进行三者的对比。

5.1 React-Native

简介 由Facebook出品,采用了JavaScript语言、JSCore引擎和通过原生渲染的跨平台框架

实现原理

通过编写JavaScript语言代码,通过 React Native 的中间层来调用 Native端的组件,最终实现相应的功能。JS端中所写控件的作用类似 Map中的key 值,对应着Native端的对应控件(如 Android 中 标签对应 ViewGroup 控件)。JS端会通过多个key 组合成Dom,最后交由Native端进行解析,最终渲染出Native端的控件。

实现框架

React Native的架构主要由三层实现。其中最重要的是由C++ 实现的中间适配层,此处最主要封装了JavaScriptCore用于执行JS的解析,最终实现了JS端与原生端的双向通信交互。而React Native运行在JavaScriptCore中。(在iOS上直接使用内置的javascriptcore、在Android则使用webkit.org官方开源的jsc.so

5.2 Weex

简介 由Alibaba出品,采用了JavaScript语言、JS V8引擎和通过原生渲染的跨平台框架

实现原理

与React-Native类似,JS端会通过多个key组合成Dom,最后交由Native端进行解析,最终渲染出Native端的控件,但区别在于:Weex是可以跨三端的 = Android、iOS、Web,其原因在于在开发过程中,代码模式、编译过程、模板组件、数据绑定、生命周期等上层语法是一致,不同的是Web端和Native端对Virtual DOM 执行的解析方法有所区别。

实现框架

weex的架构主要分为三部分,具体如下:

5.3 三者对比

注:对于性能的对比,从理论上来说Flutter应该是最接近原生性能 & 最好的,但就目前实际应用&体验中并没具备很明显的差异化,后续需进行进一步的验证。

6. 学习方式 & 资料
  • 官网:flutter.dev/

快速入门 & 学习最好的方式是:阅读Flutter官网的资源,同时官网也是了解最新Flutter发展动态的地方

  • Flutter中文网社区:flutterchina.club

目前Flutter最大的中文资源社区,提供了:Flutter官网文档翻译、开源项目 & 案例等学习资源

活跃度最高的Flutter问答社区,Flutter开发团队的成员也经常会在上面回答问题

  • 源码:https://flutter.dev/docs/development/tools/sdk/releases

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

如何做好面试突击,规划学习方向?

面试题集可以帮助你查漏补缺,有方向有针对性的学习,为之后进大厂做准备。但是如果你仅仅是看一遍,而不去学习和深究。那么这份面试题对你的帮助会很有限。最终还是要靠资深技术水平说话。

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。建议先制定学习计划,根据学习计划把知识点关联起来,形成一个系统化的知识体系。

学习方向很容易规划,但是如果只通过碎片化的学习,对自己的提升是很慢的。

同时我还搜集整理2020年字节跳动,以及腾讯,阿里,华为,小米等公司的面试题,把面试的要求和技术点梳理成一份大而全的“ Android架构师”面试 Xmind(实际上比预期多花了不少精力),包含知识脉络 + 分支细节

image

在搭建这些技术框架的时候,还整理了系统的高级进阶教程,会比自己碎片化学习效果强太多。

image

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

时候,还整理了系统的高级进阶教程,会比自己碎片化学习效果强太多。

[外链图片转存中…(img-55FoKX7r-23)]

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

到此这篇Android:手把手带你入门跨平台UI开发框架Flutter的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!

版权声明


相关文章:

  • 实战讲述Flutter跨平台框架应用,满满的干货2024-10-31 00:22:51
  • flutter 跨组件通信_前端框架flutter2024-10-31 00:22:51
  • 五大跨平台桌面应用开发框架:Electron、Tauri、Flutter等_五大跨平台桌面应用开发框架:Electron、Tauri、Flutter等2024-10-31 00:22:51
  • flutter开发桌面应用,跨平台移动开发框架2024-10-31 00:22:51
  • flutter 跨组件通信_移动开发2024-10-31 00:22:51
  • flutterapi_移动端跨平台开发2024-10-31 00:22:51
  • Android技术整理:一文秒懂Flutter跨平台演进及架构_Android技术整理:一文秒懂Flutter跨平台演进及架构2024-10-31 00:22:51
  • flutter为什么可以跨平台_用flutter开发的应用有哪些2024-10-31 00:22:51
  • flutter跨平台开发_跨平台开发语言2024-10-31 00:22:51
  • flutter跨域_flutter从入门到精通2024-10-31 00:22:51
  • 全屏图片