HarmonyOS鸿蒙2.0教程之应用知识&&梳理逻辑!

描述

上一篇我们说了环境搭建,以及注册账号,把模拟器跑起来,那么这一节就来看看,项目的目录结构。

1 项目结构剖析

我们打开项目,看到如下的目录结构,如果你不细看,一眼望去,好像安卓,或者说大致一模一样。

上一节我们去看了编译出来的hap,用zip解压出来,会发现跟apk结构类似,

这里我们把classes.dex 和 entry_debug_signed_entry.apk 都来反编译下,就能看出一些有趣的内容,对于我们理解hap会有帮助。

classes.dex 反编译的结构:

编译

会发现这里面的

MainAbilitySlice extends AbilitySlice

MainAbility extends Ability

MyApplication extends AbilityPackage

这几个都是在鸿蒙的jar包里面,我们继续看entry_debug_signed_entry.apk的反编译,这个里面会出现更多熟悉的内容:

编译

编译

通过这个关系网,就可以得出我们的应用实际实现了一个 ShellMyApplication类,来完成Application的相关工作。

然后我们又看到了:

编译

MainAbilityShellActivity extends AbilityShellActivity ,这里的AbilityShellActivity

通过这块分析,发现鸿蒙的框架,是对安卓框架做了一次封装,Activity封装成AbilityShellActivity,然后每个模块又带一个MainAbilityShellActivity。

同时 Application 封装成HarmonyApplication,然后每个模块又带一个ShellMyApplication。

于是,当前的整个逻辑就变成如下的一个结构(依据反编译信息推出的一个架构,如有错漏,欢迎交流)

同时我简单设置了断点,可以清晰的看到调用关系:

编译

然后我们再看下SDK中提供的jar包,可以看到系统抽离出来了这几个:

编译

那么我来总结下,鸿蒙系统在手机线的实现,基本上是围绕着封装来做,将安卓原始的Activity,Provider,Service,Application,进行封装,从而解析一个叫做HAP的鸿蒙应用包,完成解耦的动作。

又扯远了,我们回过头来,看看项目结构:

编译

config.json 可以类比成AndroidManifest.xml

resources 跟安卓一样,代表资源,只是目录结构有区别。

MyApplication extends AbilityPackage ,代表一个应用。

MainAbility extends Ability,可以理解成Activity,但是更准确的是没有界面的一个抽象层,可以理解成Activity管理器。

MainAbilitySlice extends AbilitySlice,这个代表一个界面,这个可以对标称Activity,一个显示界面。

从实现上来分析,HarmonyOS ,实现了一个自己的Activity,叫做

AbilityShellActivity,在真正加载起来的时候,是MainAbilityShellActivity。

而 MainAbilityShellActivity 直接操作Ability ,Ability里面有多个AbilitySlice 。

我们开发的时候,直接面对的就是Ability,生成出来就是hap文件了。关于里面的实现,只需要了解下就行。

于是我们看下逻辑图:

编译

更多参考官方文档:

https://developer.harmonyos.com/cn/docs/documentation/doc-guides/project_overview-0000001053822398

编辑:jq

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分