2024年Flutter——在Android平台上的启动流程浅析(1),哈希表 面试

总结

开发是面向对象。我们找工作应该更多是面向面试。哪怕进大厂真的只是去宁螺丝,但你要进去得先学会面试的时候造飞机不是么?

作者13年java转Android开发,在小厂待过,也去过华为,OPPO等,去年四月份进了阿里一直到现在。等大厂待过也面试过很多人。深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。

这里附上上述的技术体系图相关的几十套腾讯、头条、阿里、美团等公司的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。

相信它会给大家带来很多收获:

960页全网最全Android开发笔记

资料太多,全部展示会影响篇幅,暂时就先列举这些部分截图

当程序员容易,当一个优秀的程序员是需要不断学习的,从初级程序员到高级程序员,从初级架构师到资深架构师,或者走向管理,从技术经理到技术总监,每个阶段都需要掌握不同的能力。早早确定自己的职业方向,才能在工作和能力提升中甩开同龄人。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

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);

// flutterView 创建完成后,便会调用addView

//将 flutterSurfaceView 显示出来,只不过啥都没有而已

flutterView = new FlutterView(host.getActivity(), flutterSurfaceView);

} else {

…省略代码…

}

// Add listener to be notified when Flutter renders its first frame.

flutterView.addOnFirstFrameRenderedListener(flutterUiDisplayListener);

flutterSplashView = new FlutterSplashView(host.getContext());

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN_MR1) {

flutterSplashView.setId(View.generateViewId());

} else {

flutterSplashView.setId(486947586);

}

///这里显示闪屏页 默认是个白屏

///即,AndroidMainfest.xml 的 所设置

flutterSplashView.displayFlutterViewWithSplash(flutterView, host.provideSplashScreen());

///将flutterview 绑定到 engine上

flutterView.attachToFlutterEngine(flutterEngine);

return flutterSplashView;

}

flutterView 内部持有flutterSurfaceView (一个Surface),并最终通过attachToFlutterEngine绑定到engine上,我们来看一下其内部实现:

public void attachToFlutterEngine(@NonNull FlutterEngine flutterEngine) {

…省略部分代码…

this.flutterEngine = flutterEngine;

///通过engine的 getRenderer,

///可以将flutter的纹理绘制到android 上。

FlutterRenderer flutterRenderer = this.flutterEngine.getRenderer();

isFlutterUiDisplayed = flutterRenderer.isDisplayingFlutterUi();

renderSurface.attachToRenderer(flutterRenderer);

flutterRenderer.addIsDisplayingFlutterUiListener(flutterUiDisplayListener);

…省略部分代码…

///输入插件

textInputPlugin =

new TextInputPlugin(

this,

this.flutterEngine.getTextInputChannel(),

this.flutterEngine.getPlatformViewsController());

///国际化插件

localizationPlugin = this.flutterEngine.getLocalizationPlugin();

///与上面的textInputPlugin相关联

androidKeyProcessor =

new AndroidKeyProcessor(this.flutterEngine.getKeyEventChannel(), textInputPlugin);

/// 触摸事件的初始化

/// 相关触摸数据会发送到flutter端

androidTouchProcessor = new AndroidTouchProcessor(this.flutterEngine.getRenderer());

///辅助功能

accessibilityBridge =

new AccessibilityBridge(

this,

flutterEngine.getAccessibilityChannel(),

(AccessibilityManager) getContext().getSystemService(Context.ACCESSIBILITY_SERVICE),

getContext().getContentResolver(),

this.flutterEngine.getPlatformViewsController());

…省略部分代码…

///通过上面的初始化,将用户相关的设置发送到flutter端

sendUserSettingsToFlutter();

localizationPlugin.sendLocalesToFlutter(getResources().getConfiguration());

sendViewportMetricsToFlutter();

///将当前flutter view 绑定到 PlatformViewsController

flutterEngine.getPlatformViewsController().attachToView(this);

…省略部分代码…

}

相关初始化工作完成,activity的生命周期也从onCreate来到了onStart()

FlutterActivity & onStart()


@Override

protected void onStart() {

super.onStart();

lifecycle.handleLifecycleEvent(Lifecycle.Event.ON_START);

///重要入口

delegate.onStart();

}

delegate.onStart()此方法 最终会调用doInitialFlutterViewRun()方法:

private void doInitialFlutterViewRun() {

…省略部分代码…

// 这里就是获取我们打包所得的 libapp.so路径

// 即,我们所写的dart代码,并执行它

DartExecutor.DartEntrypoint entrypoint =

new DartExecutor.DartEntrypoint(

host.getAppBundlePath(), host.getDartEntrypointFunctionName());

flutterEngine.getDartExecutor().executeDartEntrypoint(entrypoint);

}

至此整个android端的启动流程就走完了,这里再回顾总结一下。

总结

尾声

最后,我再重复一次,如果你想成为一个优秀的 Android 开发人员,请集中精力,对基础和重要的事情做深度研究。

对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。 整理的这些架构技术希望对Android开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。

最后想要拿高薪实现技术提升薪水得到质的飞跃。最快捷的方式,就是有人可以带着你一起分析,这样学习起来最为高效,所以为了大家能够顺利进阶中高级、架构师,我特地为大家准备了一套高手学习的源码和框架视频等精品Android架构师教程,保证你学了以后保证薪资上升一个台阶。

当你有了学习线路,学习哪些内容,也知道以后的路怎么走了,理论看多了总要实践的。

进阶学习视频

附上:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题 (含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

的路怎么走了,理论看多了总要实践的。

进阶学习视频

[外链图片转存中…(img-gnupHj3i-1715716094141)]

附上:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题 (含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)

[外链图片转存中…(img-ppCOXXXF-1715716094141)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值