其他分享
首页 > 其他分享> > android开发资料!Flutter尽然还能有这种操作!灵魂拷问

android开发资料!Flutter尽然还能有这种操作!灵魂拷问

作者:互联网

2021年1月4日,我终于结束了这两个月以来收到的最好的一个公司的视频面试,短短15分钟,我们双方就再无话题了。我是觉得我不够优秀,配不上这个岗位。面试官可能觉得已经看透我了。

让我回顾一下这稍纵即逝的15分钟:

提前2分钟,面试官到达视频现场并友好提示我们开始,先做个自我介绍。

我一开始就很紧张,自我介绍说的一塌糊涂,毫无重点。但面试官很友好,一直跟我点头互动,认真听我不知所云的自我介绍。我很愧疚自责:我浪费了人家的时间。

然后面试官问我是否在找新的工作机会。我说是的,我很想要上班,看到大家在字节上班都很开心,我也想成为字节风口上的那头猪,我想跟字节一起起飞----我可能有脱口秀的潜质。

面试官问:工作中哪件事情最让你有成就感?我回答说:我带了两个新员工,并鼓励他们积极提出自己的想法,去努力试错,更愿意通过鼓励去激发,而不是批评------这个能体现我有什么能力吗?我真是服了我自己。

首先我们来看一下组件化项目和传统项目的区别:

在传统的项目里

我们通常情况下会有一个commonLib的Libary模块和一个app的application模块,业务中的逻辑都写在app中各个功能模块放到不同的包下。这样做有以下几个主要的缺点:

1.无论分包做的再好,随着项目的增大,项目会逐渐失去层次感,别人来接手的时候会很吃力。

2.我们在debug一个小功能的时候每次修改代码都需要重新build整个项目,这样显的很不合理(不知道AS的热部署有没有解决这个问题)

3.多人联合开发在版本管理中很容易出现冲突和代码覆盖的问题

在组件化项目中

除了有commonLib和app模块外,我们按照功能划分各个业务组件模块(eg:微信可以划分出chat,contract,find,mine四个大模块),之前的包变成现在的模块,增加了层次感;每个功能模块可以单独编译,加快了编译速度,也为提供单元模块测试提供了支持;多人开发只负责自己的模块,直接避免了版本管理的冲突。

图1-0组件化基本项目结构图

在明白了组件化为我们解决的主要问题后我们来看看需要怎么做

初步实现组建化其实我们最终要解决的问题就只有2个:

1.设置模块之间的依赖,且使得业务模块可单独编译–通过配置gradle即可解决
2.业务模块之间的页面跳转以及通信–使用阿里开源的ARouter即可解决
接下来我们具体来看一下如何操作
首先来看一下模块间依赖的问题
我们可以参照微信的四个模块(chat,contract,find,mine)来配置

首先我们项目基本结构如下:

图1-1项目结构

我们一共需要建6个module,除了4个功能模块外还有一个基本的common库和一个作为启动的application。

在建好项目后我们需要给4个module配置一个是否单独编译的开关:

图1-2单独编译各个模块的开关

关于开关的配置位置这是一个问题,我们把它添加在gradle.properties文件中,这样我们每次修改值的时候就可以触发gradle的重新构建,便于我们单独编译module。

我们单独编译的开关配置好了,现在我们来配置6个module之间的依赖关系:

图1-3app和功能lib的基础依赖

首先,为了方便各个module之间的交互我们借用了阿里的充分ARouter库,所以在每个非common的库(包括主Application)中我都强烈建议加入对ARouter和commonlib的依赖。

其次,4个功能模块库我们要为它装上我们之前配置的是否单独编译的开关,我们需要修改如下2个地方:

图1-4功能模块配置单独编译开关

可以看到我们要修改的就是我红框框住的地方,当我们的开关打开的时候,我们就把他当成一个单独的application来编译,并且赋予它一个独一无二的applicationId,这样我们就可以通过刚刚在gradle.properties中配置的开关来控制它是否单独作为一个application来编译。

而对于我们的入口module–app模块我们则需要做如下的配置:

图1-5主module的gradle配置

我们除了需要配置基本的ARouter以及commonlib依赖以外还需要在app模块的gradle文件中根据开关选择是否需要依赖我们的功能模块,这个和各个功能模块中的配置是相呼应的。

而对于其他组件模块,重复上述步骤即可完成组件化框架的搭建:

图1-6项目结构图

在完成了组件化框架的搭建后我们来简单的看看框架中一些具有特色的使用方法。

我们首先来看一下各个模块的页面间是怎样跳转的。

我们之前已经依赖了ARouter,我们要用它来帮我们实现跳转需要以下几步:

图2-1

跳转的方法就如同图2-1中显示,我们需要标明目标页面,附带上要传送的参数,然后调用navigation()就可以跳转了,不过有人问目标页面怎么看着就是一个路径,它是怎样定义的?

图2-2目标页面的配置

这样,我们就完成了页面间的跳转了,是不是比起我们传统的方法更加简单合理?

最后我们来看一下组件间如何为彼此提供服务。

图3-1公共接口的定义
首先在commonlib模块里创建一个暴露方法的接口,并定义接口签名,同时继承 Iprovider 接口

然后在home模块中继承commonlib里定义的接口,并实现签名方法。

图3-2在提供方法的module中的配置

这里我们同样使用Arouter的 @Router注解来提供这次服务的路由。

最后,我们在其他模块使用 @Autowired 注解就可以调用该方法了

图3-3对于方法的调用

可以看到我们同样使用了@Autowired注解来初始定baseService服务,并将页面注入Arouter中即可调用服务中的方法,且对于服务的依赖是基于接口的依赖,大大提高了其灵活性!

文末

很多人在刚接触这个行业的时候或者是在遇到瓶颈期的时候,总会遇到一些问题,比如学了一段时间感觉没有方向感,不知道该从那里入手去学习,对此我整理了一些资料,需要的可以免费分享给大家

这里笔者分享一份自己收录整理上述技术体系图相关的几十套腾讯、头条、阿里、美团等公司2021年的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。如有需要点击这里前往免费获取

【视频教程】

天道酬勤,只要你想,大厂offer并不是遥不可及!希望本篇文章能为你带来帮助,如果有问题,请在评论区留言。

1616147515249)]

【视频教程】

[外链图片转存中…(img-NsCiRlDX-1616147515250)]

天道酬勤,只要你想,大厂offer并不是遥不可及!希望本篇文章能为你带来帮助,如果有问题,请在评论区留言。

标签:尽然,module,我们,编译,模块,组件,android,Flutter,页面
来源: https://blog.csdn.net/m0_56251953/article/details/115012423