Flutter——在Android平台上的启动流程浅析(1)

Flutter应用是由平台(及native)来创建、初始化并启动的,这里我们以android为例,对启动过程做一个走马观花式的了解,旨在对平台端的工作有个大致了解。

Android端的启动流程

=============

启动流程实际上还涉及了很多native 层的工作,但是宥于篇幅,暂且只看Android端。

FlutterApplication


flutter应用下,原生的启动流程并没有什么变化,我们来看Application的onCreate函数。

@Override

@CallSuper

public void onCreate() {

super.onCreate();

FlutterMain.startInitialization(this);

}

很简单,继续往里走

public static void startInitialization(@NonNull Context applicationContext) {

if (isRunningInRobolectricTest) {

return;

}

FlutterLoader.getInstance().startInitialization(applicationContext);

}

上面的方法用于初始化 native system(即C++),并最终会调用下面的方法:

我将说明以注释的形式写在下面

public void startInitialization(@NonNull Context applicationContext, @NonNull Settings settings) {

if (this.settings != null) {

return;

}

///确保运行在 主线程

if (Looper.myLooper() != Looper.getMainLooper()) {

throw new IllegalStateException(“startInitialization must be called on the main thread”);

}

// Ensure that the context is actually the application context.

final Context appContext = applicationContext.getApplicationContext();

this.settings = settings;

initStartTimestampMillis = SystemClock.uptimeMillis();

///配置 aotSharedLibraryName、flutterAssetsDir、

/// vmSnapshotData、isolateSnapshotData

///等参数

initConfig(appContext);

///初始化VsyncWaiter,并设置回调

/// 当vsync信号到来时,就调用我们设置的回调,最终会触发页面的刷新

VsyncWaiter.getInstance((WindowManager) appContext.getSystemService(Context.WINDOW_SERVICE))

.init();

// 子线程

///这里主要是抽取资源文件,

///加载 flutter(libflutter.so)代码

Callable initTask =

new Callable() {

@Override

public InitResult call() {

ResourceExtractor resourceExtractor = initResources(appContext);

System.loadLibrary(“flutter”);

// Prefetch the default font manager as soon as possible on a background thread.

// It helps to reduce time cost of engine setup that blocks the platform thread.

Executors.newSingleThreadExecutor()

.execute(

new Runnable() {

@Override

public void run() {

FlutterJNI.nativePrefetchDefaultFontManager();

}

});

if (resourceExtractor != null) {

resourceExtractor.waitForCompletion();

}

return new InitResult(

PathUtils.getFilesDir(appContext),

PathUtils.getCacheDirectory(appContext),

PathUtils.getDataDirectory(appContext));

}

};

initResultFuture = Executors.newSingleThreadExecutor().submit(initTask);

}

至此FlutterApplication 的相关流程就走完了。

另外,虽然上面的代码中使用了子线程,但是最终在这些任务没有完成前,是不会进入flutter侧的,我们接着走FlutterActivity。

FlutterActivity & onCreate


开始的地方依然是 onCreate()方法:

@Override

protected void onCreate(@Nullable Bundle savedInstanceState) {

///切换主题

switchLaunchThemeForNormalTheme();

super.onCreate(savedInstanceState);

///通知生命周期

lifecycle.handleLifecycleEvent(Lifecycle.Event.ON_CREATE);

///初始化delete,这个很重要,

///所有的工作都是由它来完成的

delegate = new FlutterActivityAndFragmentDelegate(this);

delegate.onAttach(this);

///是否需要恢复(包括通知插件)一些状态

delegate.onActivityCreated(savedInstanceState);

///配置窗口

configureWindowForTransparency();

///创建flutterView

setContentView(createFlutterView());

configureStatusBarForFullscreenFlutterExperience();

}

这里面比较重的代码是这几行:

delegate = new FlutterActivityAndFragmentDelegate(this);

delegate.onAttach(this);

setContentView(createFlutterView());

我们一步一步来,首先创建了FlutterActivityAndFragmentDelegate 并调用了它的attact(this)方法。

FlutterActivityAndFragmentDelegate


void onAttach(@NonNull Context context) {

ensureAlive();

///初始化engine

if (flutterEngine == null) {

///这里面会对已有的engine进行复用

setupFlutterEngine();

}

///初始化平台插件

///本质上,是将engine的 channel回调与平台的系统服务进行绑定

///如:震动、复制粘贴、声音播放等…

platformPlugin = host.providePlatformPlugin(host.getActivity(), flutterEngine);

if (host.shouldAttachEngineToActivity()) {

Log.v(TAG, “Attaching FlutterEngine to the Activity that owns this Fragment.”);

/// 激活 原生viewController

/// 并通知相关插件

/// PlatformViewsController 这个类你应该很熟悉(如果你接入过原生view的话)

flutterEngine

.getActivityControlSurface()

.attachToActivity(host.getActivity(), host.getLifecycle());

}

///注册插件

///通过反射调用 “io.flutter.plugins.GeneratedPluginRegistrant”

///的 “registerWith”方法,这个过程走完了,你的插件基本就能用了

host.configureFlutterEngine(flutterEngine);

}

通过上面,我们大致了解了,在flutter端使用的平台功能是什么时候装配的了。

我们回到FlutterActivity,继续重要的第二步:

setContentView(createFlutterView());

@NonNull

private View createFlutterView() {

return delegate.onCreateView(

null /* inflater /, null / container /, null / savedInstanceState */);

}

最终会调用 delete的onCreateView :

@NonNull

View onCreateView(

LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {

Log.v(TAG, “Creating FlutterView.”);

ensureAlive();

if (host.getRenderMode() == RenderMode.surface) {

///一般flutter应用是 RenderMode.surface,所以会进入到这里

///创建FlutterSurfaceView

FlutterSurfaceView flutterSurfaceView =

new FlutterSurfaceView(

host.getActivity(), host.getTransparencyMode() == TransparencyMode.transparent);

// Allow our host to customize FlutterSurfaceView, if desired.

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

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

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

img

img

img

img

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

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

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

总结

学习技术是一条慢长而艰苦的道路,不能靠一时激情,也不是熬几天几夜就能学好的,必须养成平时努力学习的习惯。所以:贵在坚持!

最后如何才能让我们在面试中对答如流呢?

答案当然是平时在工作或者学习中多提升自身实力的啦,那如何才能正确的学习,有方向的学习呢?有没有免费资料可以借鉴?为此我整理了一份Android学习资料路线:

这里是一部分我工作以来以及参与过的大大小小的面试收集总结出来的一套BAT大厂面试资料专题包,主要还是希望大家在如今大环境不好的情况下面试能够顺利一点,希望可以帮助到大家。

好了,今天的分享就到这里,如果你对在面试中遇到的问题,或者刚毕业及工作几年迷茫不知道该如何准备面试并突破现状提升自己,对于自己的未来还不够了解不知道给如何规划。来看看同行们都是如何突破现状,怎么学习的,来吸收他们的面试以及工作经验完善自己的之后的面试计划及职业规划。

最后,祝愿即将跳槽和已经开始求职的大家都能找到一份好的工作!

这些只是整理出来的部分面试题,后续会持续更新,希望通过这些高级面试题能够降低面试Android岗位的门槛,让更多的Android工程师理解Android系统,掌握Android系统。喜欢的话麻烦点击一个喜欢再关注一下

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!

小小的面试收集总结出来的一套BAT大厂面试资料专题包,主要还是希望大家在如今大环境不好的情况下面试能够顺利一点,希望可以帮助到大家。

[外链图片转存中…(img-z9R9BKv6-1711818652515)]

好了,今天的分享就到这里,如果你对在面试中遇到的问题,或者刚毕业及工作几年迷茫不知道该如何准备面试并突破现状提升自己,对于自己的未来还不够了解不知道给如何规划。来看看同行们都是如何突破现状,怎么学习的,来吸收他们的面试以及工作经验完善自己的之后的面试计划及职业规划。

最后,祝愿即将跳槽和已经开始求职的大家都能找到一份好的工作!

这些只是整理出来的部分面试题,后续会持续更新,希望通过这些高级面试题能够降低面试Android岗位的门槛,让更多的Android工程师理解Android系统,掌握Android系统。喜欢的话麻烦点击一个喜欢再关注一下

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值