android12/13/14版本wms最新面试题:dumpsys window和sf一定会一致么?

背景:

近期学员们学习了马哥wms课程后,去参加相关的大厂的framework面试,有一个学员朋友带回来了一个wms相关的面试题,具体面试题描述如下:
问题1

请问wms的window和SurfaceFlinger的Layer有什么关系?

回答了这问题1后,紧接着会继续深入问问题2

问题2
既然二者关系是一一对应的,那么请问wms层面的层级结构树就一定和SurfaceFlinger层面的Layer结构树一定一致么?
如果回答了不一致,会要求列举出几种不一致的情况(这里还会对列出的情况还进行深入挖)。

基于上面这个2个面试题,其实本质上是对wms还有surfaceflinger相关知识的深入考察,而且问题属于难度等级层次分明,慢慢变大的情况,所以要完全可以拿捏对这问题,基本上wms部分的知识考察就可以得到面试官的高度认可打高分。
那么下面来剖析一下如何得上面问题的高。

面试题回答和剖析

问题1

请问wms的window和SurfaceFlinger的Layer有什么关系?

难度评价: 中
考察wms理解,SurfaceFlinger的理解

这个其实课程就已经和大家讲解的很清楚了,高版本android把引入了窗口层级结构树的概念,这个树上的任意节点其实都是继承了WindowContainer类,WindowContainer在创建或者添加时候都会产生一个对应的SurfaceControl,而SurfaceControl又会触发到SurfaceFlinger创建一一对应的Layer,而且WindowContainer的层级结构关系都会一一影响自己SurfaceControl,所以一般在SurfaceFlinger也会有一个和wms一一对应Layer结构树。

问题2

请问wms层面的层级结构树就一定和SurfaceFlinger层面的Layer结构树一定一致么?

难度评价: 较高

问题1属于考查wms理论知识后,开始要加大难度考察wms的深入实战理解知识,即这个问题如果你平时只是学习了wms理论知识,理解了层级结构树,但是没有做过较多wms相关的实战项目及丰富经验。那么这个问题很可能就答不上来,因为在正常情况下,确实wms的层级结构树都是与Sf的Layer结构树完全一致

那么什么时候不一致呢,不一致又有哪些情况呢?
这个面试问题课程可能没有现成的答案,但是课程其实也都有讲解过不一致的情况,具体列出几个经典的案例场景

1、经典的学习车载多屏互动课程时候,是不是有创建单独Mirror图层,一直靠操作这个Mirror图层来进行的操作画面,但是并没有在wms成名创建对应的WindowContainer。

2、学习分屏PIP自由窗口专题时候,有讲解PIP的顶层WindowLess的部分,是不是就是在dumpsys window方式看不到任何的window,但是确实有相关Sf的Layer情况。

3、还有在以前直播时候也讲解过,普通的InputMonitor全局监听事件和monitorGestureInput有啥区别?本质就是GestureInput额外多了图层在sf中。

4、blog有分享过ActivityRecordInputSink相关的剖析,他也是个典型的sf中有图层,但是window中没有。

上面若干案例其实都有一个共同点,都明显表达出一个结论:

sf中的图层不一定window中有,即sf图层可以单独创建挂载不受window的约束和影响,即sf的图层一般比window多的情况。

问题要是可以回答到以上几点其实基本上就算过关了,但是如果还要深挖,那么可能还有有如下的问题:

是否有遇到过sf中的Layer图层和window结构树数目对象都一样,但是顺序不一样,如果有遇到过请举例一下案例。

这种其实就是对一些少见的疑难bug问题的分析经验的考察,看看你是否有遇到过同类型的疑难杂症。
针对这个问题,其实就是说window结构树顺序依赖关系和sf的Layer结构树依赖关系居然不同,大家也知道正常情况下肯定要一模一样,因为Layer虽然可以新加入,但是不能说原来的window对应的Layer结构树顺序都乱了,这样可能会造成显示类的bug。

在这里插入图片描述
正常dumpsys activity containers看到是com.android.messaging/.ui.conversation.ConversationActivity在顶部显示者,但如果dumpsys SurfaceFlinger 发现确实com.android.launcher3/com.android.launcher3.uioverrides.QuickstepLauncher显示,而短信却被显示在桌面下面即被遮盖了,无法显示出来。

如果有遇到过这类的问题再聊一下相关分析和经验那么问题也就完美得分肯定也会额外加分。

更多framework详细代码和资料参考如下链接
投屏专题部分:

https://mp.weixin.qq.com/s/IGm6VHMiAOPejC_H3N_SNg

hal+perfetto+surfaceflinger

https://mp.weixin.qq.com/s/LbVLnu1udqExHVKxd74ILg
其他课程七件套专题:在这里插入图片描述
点击这里
https://mp.weixin.qq.com/s/Qv8zjgQ0CkalKmvi8tMGaw

视频试看:
https://www.bilibili.com/video/BV1wc41117L4/

参考相关链接:
https://blog.csdn.net/zhimokf/article/details/137958615

更多framework假威风耗:androidframework007


http://www.niftyadmin.cn/n/5682522.html

相关文章

【Linux实践】实验五:用户和组群账户管理

【Linux实践】实验五:用户和组群账户管理 实验目的实验内容实验步骤及结果1. 创建用户2. 切换用户3. 修改用户4. 删除用户5. 创建组群6. 修改组群补充:删除组群 实验目的 1、掌握字符界面下用户账户的设置,包括命令useradd、usermod、userde…

浅谈计算机神经网络基础与应用

1. 绪论 随着科技的飞速发展,人工智能(AI)已经逐渐渗透到我们生活的方方面面。作为AI技术的核心组成部分,神经网络在推动这一领域的发展上扮演着至关重要的角色。本报告旨在探讨AI中的不同类型神经网络及其在实际应用中的表现和影响。我们将从神经网络的基本概念入手,逐步…

代码随想录Day17 图论-3

并查集理论基础 学习并查集 我们就要知道并查集可以解决什么问题 并查集主要有两个功能&#xff1a; 将两个元素添加到一个集合中判断两个元素在不在同一个集合 以下是代码模板 int n 1005; // n根据题目中节点数量而定&#xff0c;一般比节点数量大一点就好 vector<i…

vue3项目中使用Tailwind CSS

创建vue3项目&#xff08;使用vite&#xff09; 1.首先&#xff0c;在新的文件夹中初始化一个项目&#xff0c;使用Vite创建项目&#xff1a; npm create vitelatest my-vue3-ts-tailwind-vite --template vue-ts2.进入项目目录安装依赖 cd my-vue3-ts-tailwind-vite npm in…

召回08 双塔模型——线上服务、模型更新

线上召回 离线存储&#xff1a; 模型训练好之后&#xff0c;部署到线上做召回&#xff0c;快速找到用户感兴趣的物品。 对训练好的两个塔&#xff0c;线上服务前&#xff0c;先用右边的物品塔提取物品的特征做离线存储&#xff0c;记作特征向量b&#xff0c;把&#xff08;b…

【有啥问啥】具身智能(Embodied AI):人工智能的新前沿

具身智能&#xff08;Embodied AI&#xff09;&#xff1a;人工智能的新前沿 引言 在人工智能&#xff08;AI&#xff09;的进程中&#xff0c;具身智能&#xff08;Embodied AI&#xff09;正逐渐成为研究与应用的焦点。具身智能不仅关注于机器的计算能力&#xff0c;更强调…

OpenCV视频I/O(11)设置视频捕获设备的属性函数 set()的使用

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 在 VideoCapture 中设置一个属性。 在OpenCV中&#xff0c;cv::VideoCapture::set() 函数用于设置视频捕获设备的属性。这些属性可以包括分辨率、…

华为-单臂路由

1、什么是单臂路由 单臂路由&#xff08;Single-Arm Routing&#xff09;是一种网络架构和配置技术&#xff0c;它允许路由器通过一个物理接口来管理多个虚拟局域网&#xff08;VLAN&#xff09;之间的通信。 这个物理接口被配置为Trunk模式&#xff0c;以便能够传输来自不同VL…