一文理解模块化、组件化、插件化的区别,2024年最新android实战开发项目阅读器

这种模式不涉及乱七八糟的处理方式, 上手快,开发快,足够敏捷。那么原因是什么呢?Mobile Project 刚起步,项目都偏小,一些附加业务还没绑到App上。

1、模块化

Android Studio出来了,多出来了一个新的概念, Project, Module… 模块;当时以包的形式分离的公共包common,现在成了AS中的Module。

大家都知道,Module包含两种格式: application, library。也就是说,一个Module就是一个小的项目,也是AS概念中的模块。

因此我们开始设计common模块, common_business模块,甚至db模块。模块的好处是什么?

相比于包来讲,模块更灵活,耦合更低,随意插拔,想引入哪个就引入哪个。根据不同的关注点,将一个项目的可以共享的部分抽取出来,形成独立的Module,就是模块化。

当然,模块化不只包含公共部分,当然也可以是业务模块。

2、组件化

平时看看论坛,好多人都在问: 模块化和组件化有什么区别? 到底有什么区别呢,其实很小;但并不是完全相同的概念。 通过以上模块化的概念讲述,应该对模块化有了一个了解,那么区别是什么呢?

组件化是建立在模块化思想上的一次演进,一个变种。组件化本来就是模块化的概念。但是组件化的核心是 什么? 是模块角色的可转换性。是的,就是可转换性。

组件化的核心是角色的转换。 在打包时, 是library; 在调试时, 是application。

怎么理解组件化的概念 ?

Module的模式分两种, application和library

library就是引用库,如你抽取的common。 而application就是一个apk, 是一个完整的项目。

在调试时,我只关心我负责的模块,我希望我的模块是一个单独的app,因为这样更小,业务更专一,相对来讲修改与调试就会越省时省心,编译就会越快。试想当你需要改一段代码,既要关注自己的,也要关注别人的,是一种什么体验 ? 或者, 编译一个项目10M的代码和一个工程全部1G的代码,哪个比较舒服一些?

3、 插件化

又有人问了:插件化和组件化又有什么区别呢?

插件化严格意义来讲,其实也算是模块化的观念。将一个完整的工程,按业务划分为不同的插件,都是分治法的一种体现。化整为零,相互配合。越小的模块越容易维护。

插件化按理也算是模块化的一种体现,和组件化就不一个概念了。那么,到底有什么区别呢?

组件化的单位是组件(module)。

插件化的单位是apk(一个完整的应用)。

组件化实现的是解耦与加快编译, 隔离不需要关注的部分。

插件化实现的也是解耦与加快编译,同时实现热插拔也就是热更新。

组件化的灵活性在于按加载时机切换,分离出独立的业务组件,比如微信的朋友圈

插件化的灵活性在于是加载apk, 完全可以动态下载,动态更新,比组件化更灵活。

组件化能做的只是, 朋友圈已经有了,我想单独调试,维护,和别人不耦合。但是和整个项目还是有关联的。

插件化可以说朋友圈就是一个app, 我需要整合了,把它整合进微信这个大的app里面

其实从框架名称就可以看出: 组 和 插。

组本来就是一个系统,你把微信分为朋友圈,聊天, 通讯录按意义上划为独立模块,但并不是真正意义上的独立模块。

插本来就是不同的apk, 你把微信的朋友圈,聊天,通讯录单独做一个完全独立的app, 需要微信的时候插在一起,就是一个大型的app了。

插件化的加载是动态的,这点很重要,也是灵活的根源。

以上是对三个思想的解析,相信应该能明白不同的概念的具体意义和区别在哪了。

4、子模块划分

除了大家公认的common部分, 业务模块的划分尤为重要,相比于狭义上的架构,广义上的子系统的划分的关注点,很考验技术经验以及对业务的理解。

5、通信方式

模块化的通信方式,无非是相互引入;我抽取了common, 其他模块使用自然要引入这个module 组件化的通信方式,按理说可以划分为多种,主流的是隐式和路由。隐式的存在使解耦与灵活大大降低,因此路由是主流 插件化的通信方式,不同插件本身就是不同的进程了。因此通信方式偏向于Binder机制类似的进程间通信

废话说了这么多,其实本篇作为组件化的引导篇,主要是想让大家掌握组件化开发。网上有很多关于学习组件化开发思路的文章,组件化原理很简单,但是真正实施起来还是挺困难的,没有相应的实战+源码参考就做好踩坑的准备吧。

最近小编有幸在字节跳动高工手里扒到这份“组件化实战学习手册”,这位大佬主导开发过多个采用组件化架构的APP项目。现在我只想吹爆!这位大佬熬夜半个月,把积累的经验和踩的坑都进行了总结,整理成了长达220页的学习手册,手册中收录了大厂热门的组件化项目实战,从新手到架构师,这份学习手册足以。

第一章 Android组件化初识
  • 组件化和模块化的区别

  • 组件化和插件化的区别

  • 组件化开发的优势

  • 业务逻辑层

  • 组件化开发要遇到的问题

  • 从组件化实战来解决问题

  • Android组件化基础

……

第二章 Android组件化初探目录
  • 组件化演示案例

概述

模块化和组件化

组件化Demo

组件application和library动态切换

……

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

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

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

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

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

如果你觉得这些内容对你有帮助,可以添加V获取:vip204888 (备注Android)
img

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

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

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

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

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

image

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

image

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

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

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

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

  • 16
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Pinia是一个用于Vue.js 3的状态管理库,它可以帮助我们更好地组织和管理应用程序的状态。在Vue.js 3中使用Pinia进行模块化状态管理有几个步骤。 首先,我们需要在项目中安装Pinia库。可以通过npm或yarn来安装Pinia。 ``` npm install pinia ``` 或 ``` yarn add pinia ``` 接下来,我们需要创建一个或多个store文件来定义我们的模块。每个store文件对应一个模块。例如,我们可以创建一个`userStore.ts`文件来管理用户相关的数据,创建一个`systemStore.ts`文件来管理系统相关的数据。 在`userStore.ts`中,我们可以定义一个`UserStore`类,该类使用Pinia的`defineStore`函数来定义模块的状态和相关的操作。在这个类中,我们可以定义我们需要的状态属性和方法。 ```typescript import { defineStore } from 'pinia' export const userStore = defineStore({ id: 'user', state: () => ({ name: '', age: 0, email: '' }), actions: { setName(name: string) { this.name = name }, setAge(age: number) { this.age = age }, setEmail(email: string) { this.email = email } } }) ``` 在`systemStore.ts`中,我们可以按照同样的方式定义系统相关的状态和操作。 接下来,我们需要创建一个根store来整合所有的模块。我们可以创建一个`store.ts`文件,使用Pinia的`createPinia`函数来创建一个根store实例。 ```typescript import { createPinia } from 'pinia' export const pinia = createPinia() ``` 最后,在我们的Vue应用程序的入口文件中,我们需要将Pinia插件添加到Vue应用程序中。 ```typescript import { createApp } from 'vue' import App from './App.vue' import { pinia } from './store' const app = createApp(App) app.use(pinia) app.mount('#app') ``` 现在,我们就可以在我们的组件中使用Pinia的`useStore`函数来获取我们定义的各个模块的实例,并使用它们的状态和操作。 ```typescript import { useStore } from 'pinia' export default { setup() { const userStore = useStore('user') // 使用userStore的状态和操作 userStore.setName('John') console.log(userStore.name) return { userStore } } } ``` 通过这种方式,我们可以将应用程序的状态按照模块进行组织和管理,使得代码更加清晰和可维护。每个模块都有自己的状态和操作,最后通过根store进行整合。这样可以更好地实现模块化管理。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Vue3 - Pinia 模块化(详细教程)](https://blog.csdn.net/weixin_44198965/article/details/128114009)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [【一文搞定Pinia】超详细的Pinia教程,比Vuex香太多了!](https://blog.csdn.net/weixin_42373175/article/details/128268962)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值