当前位置: 首页 > article >正文

使用Perfetto进行Settings中网络热点开启后anr分析的整体流程记录

目录一.背景二.Perfetto使用流程阶段一抓取 Perfetto Trace 文件1. 指令核心解析2. 数据源功能详解 (这些是抓取的“维度”)3. 该指令的作用场景阶段二导入并认识 Perfetto UI 面板1. 致命异常Duration: (Did not end)2. 定位到的业务范围1. 核心异常CPU 4 被 dnsmasq 进程占满2. 线程唤醒关系system_server 在“垂死挣扎”3. 渲染线程 (RenderThread) 的反常表现综合诊断结果三.结合日志排查1. 核心含义dnsmasq 疯了CPU 占用接近 100%2. 为什么会导致 Settings ANR3. dnsmasq 是干什么的TetherOffload HAL 与 dnsmasq1. 技术背景为什么需要 TetherOffload2. TetherOffload 的作用3. 两者的具体协作与区别协作流程4. 总结它们是互补的四.修复TetherOffload 相关内容后一.背景测试提了一个问题Settings中打开热点后直接卡死然后anr之前我一般都是通过日志和AndroidStudio Profile进行分析的需要看我之前分析流程的可以参考如下资料https://blog.csdn.net/gongjdde/article/details/134859886本次使用Perfetto结合日志进行排查二.Perfetto使用流程阶段一抓取 Perfetto Trace 文件抓取数据主要有两种方式对于排查系统层面的服务死锁和底层阻塞强烈推荐使用命令行方式因为你可以精确配置需要监控的数据源。1. 命令行方式推荐通过adb连接你的测试设备在终端输入以下命令。这个命令会抓取 CPU 调度、系统调用、Binder 通信以及核心系统服务的状态。adb shell perfetto -o /data/misc/perfetto-traces/trace_file.perfetto-trace -t 15s sched freqs idle am wm gfx view binder_driver hal dalvik res-t 15s表示持续抓取 15 秒。你可以先敲下回车开始录制然后在手机上迅速复现那个“打开网络设置导致卡顿”的操作。以下是对该指令各部分的详细拆解1. 指令核心解析adb shell: 通过 ADB 在 Android 设备内部执行命令。perfetto: 调用系统中的性能跟踪程序。-o /data/misc/perfetto-traces/trace_file.perfetto-trace:指定输出文件的存储路径。路径通常位于/data/misc/perfetto-traces/因为该目录具有合适的读写权限抓取完毕后可以用adb pull将文件传回电脑进行分析。-t 15s: 指定跟踪时长为 15 秒。执行后系统会立即开始记录15 秒后自动停止并保存文件。[数据源列表]: 紧跟在末尾的参数sched freqs idle am wm gfx view binder_driver hal dalvik res是数据源Data Sources用于指定需要记录哪些内核和应用层的事件。2. 数据源功能详解 (这些是抓取的“维度”)这些参数决定了 Trace 文件中包含哪些信息sched:调度器事件。记录 CPU 线程的调度信息Task 切换、唤醒、休眠。这是分析“卡顿”最核心的数据。freqs:频率信息。记录 CPU 频率CPU Freq的变化。用于分析是否存在 CPU 降频导致性能不足。idle:空闲状态。记录 CPU 进入 Idle 状态的时间点分析功耗问题。am(Activity Manager): 记录 Android 系统的 Activity 启动、生命周期事件。wm(Window Manager): 记录窗口管理器的相关事件比如窗口的显示、隐藏、Layer 的刷新。gfx(Graphics):图形相关。记录 SurfaceFlinger、Vsync、渲染帧等关键信息分析掉帧Jank必备。view:View 系统事件。记录 Android UI 控件的 Measure、Layout、Draw 流程。binder_driver:Binder 驱动事件。记录进程间通信IPC的详细耗时分析是哪个服务调用导致了阻塞。hal:HAL 层事件。记录硬件抽象层如 Camera、传感器、音频 HAL的调用分析硬件驱动层的延迟。dalvik:虚拟机事件。记录 GC垃圾回收、JIT 编译等事件。res:资源加载。记录一些资源加载、系统属性的变化。3. 该指令的作用场景这个指令通常用于排查性能卡顿Jank/Lag或功耗异常。场景 1分析 UI 卡顿通过gfx和view可以看到 UI 刷新是否掉帧。通过sched和binder_driver可以分析是否因为某个线程一直抢占 CPU 或被某个 Binder 调用阻塞导致界面无法及时响应。场景 2分析应用启动慢通过am和wm可以看到 Activity 启动的完整过程配合binder_driver找出在哪个通信环节耗时过长。场景 3分析功耗或发热通过freqs和idle结合sched查看 CPU 是否一直保持高频或者频繁进行不必要的线程唤醒。完成后将生成的 Trace 文件 pull 到电脑上adb pull /data/misc/perfetto-traces/trace_file.perfetto-trace .阶段二导入并认识 Perfetto UI 面板拿到 Trace 文件后我们需要使用 Google 提供的网页端工具来可视化分析。1. 打开网页加载数据在浏览器推荐 Chrome 或 Edge中打开官方分析工具ui.perfetto.dev 将刚才导出的.perfetto-trace文件直接拖拽进网页中央。2. 核心操作快捷键必记Perfetto 的界面信息量极其庞大单纯依靠鼠标拖拽效率很低熟练使用以下快捷键是必备技能W / S放大 / 缩小时间轴Zoom In / Out。这在精确定位毫秒级耗时时非常有用。A / D向左 / 向右平移时间轴。M高亮选中一段区域。鼠标框选一段时间后按 M可以固定高亮用于查看这段时间内的系统整体负载。如下是将trace文件导入到网页后的界面1. 致命异常Duration: (Did not end)这是最核心的发现。含义performCreate这个方法一直没有执行完。分析在 Perfetto 录制的这段时间里甚至直到录制结束主线程都卡在这个方法内部。按照 Android 机制主线程被阻塞超过 5 秒就会触发 ANR。你这里的阻塞长度已经贯穿了整个 Trace 视图说明主线程彻底“死”在了SubSettings的创建过程中。2. 定位到的业务范围Name:performCreate:com.android.settings.SubSettings分析这说明点击设置项大概率是网络相关的二级菜单后系统尝试初始化SubSettings页面。所有该页面的Fragment初始化、onCreate生命周期逻辑、以及各种Preference状态的获取都在这个方法里同步执行。然后我们继续看上面有没有什么异常1. 核心异常CPU 4 被dnsmasq进程占满在第二张图的CPU 4 Scheduling轨道上你可以看到大段的橙黄色块上面标注着进程名为dnsmasq [5252]。现象dnsmasq在 CPU 4 上几乎是持续运行的这意味着它在进行高强度的任务。关联性dnsmasq通常与热点Tethering和 DNS 转发相关。结合你之前日志里提到的tetheroffload报错这说明在你打开设置页面的那一刻热点相关的网络后台进程正在发生严重的异常可能是死循环或大量的网络包处理。2. 线程唤醒关系system_server在“垂死挣扎”查看右下角的Scheduling Latency面板Wakeup信息显示RenderThread 4589是被system_server [1926]里的binder:1926_5唤醒的。分析这证实了system_server一直在试图与Settings进程通信。但由于dnsmasq占用了大量资源或者dnsmasq阻塞了某种系统级的网络锁Mutex导致通信效率极低。3. 渲染线程 (RenderThread) 的反常表现现象第一张图显示main thread卡死在performCreate紫色长条但下方的RenderThread却有密集的绿条和prepareAndDraw。解释这说明Settings的 UI 逻辑层主线程已经彻底瘫痪了但渲染层RenderThread还在尝试刷新画面比如显示一个进度条或者处理上一次的绘制请求。这种“主线程死锁渲染线程还在跑”的现象是典型的同步逻辑阻塞。综合诊断结果这是一个由网络子系统dnsmasq/Tethering引起的系统级阻塞导致的 ANR。根源dnsmasq进程异常占用了核心 CPU 资源。连锁反应当你进入SubSettings网络设置页面时主线程发起了一个同步请求去获取热点或网络配置。死锁由于dnsmasq处于异常状态或者它持有了某个底层的硬件访问锁导致Settings发出的请求永远得不到回应。结果主线程在performCreate阶段永久等待5 秒后触发 ANR。上述是整个Perfetto的排查流程它排查出可能是网络子系统dnsmasq/Tethering引起的系统级阻塞导致的 ANR。然后我们继续结合日志进行后续排查三.结合日志排查首先抓取dnsmasq日志 执行adb logcat | grep dnsmasq看看有没有timeout或failed to bind之类的报错。这几行日志是ANR应用无响应调查的“冒烟证据”。它解释了为什么你的Settings进程会卡死系统资源被耗尽了。具体分析如下1. 核心含义dnsmasq疯了CPU 占用接近 100%日志显示dnsmasq进程号 5252持续占用了95% - 98%的 CPU 资源。User (用户态)vsKernel (内核态)在00:00:47之后的记录中dnsmasq的Kernel 占用高达 85% 左右。这说明dnsmasq并不是在做复杂的计算而是陷入了某种严重的内核级阻塞或死循环。它可能在不停地尝试读写一个损坏的网卡接口、处理海量的恶意网络包或者在不停地申请/释放内核锁。2. 为什么会导致SettingsANR结合你之前的 Perfetto 图表逻辑链条现在闭合了抢占资源dnsmasq几乎吃光了 CPU 资源尤其是你截图里看到的 CPU 4。Binder 响应超时当你在Settings里打开网络设置时主线程需要通过 Binder 去问system_server现在的网络状态。由于 CPU 被dnsmasq占满加上可能存在的内核锁竞争这个 Binder 请求发不出去或者回不来。主线程挂起主线程在performCreate阶段等不到数据直接卡死。3.dnsmasq是干什么的在 Android 中dnsmasq主要负责热点Tethering为连接到你手机热点的设备分配 IP 地址DHCP和解析域名DNS。如果你当时开启了热点或者有设备正在频繁尝试连接你的热点可能触发了它的 Bug。然后我们看下logcat中关键的日志如下日志是一直反复出现2025-09-10 14:20:31.719 3214-3251 HidlServiceManagement com.android.networkstack.process W Waited one second for android.hardware.tetheroffload.config1.0::IOffloadConfig/default 2025-09-10 14:20:31.719 692-692 hwservicemanager hwservicemanager I Since android.hardware.tetheroffload.config1.0::IOffloadConfig/default is not registered, trying to start it as a lazy HAL (if its not configured to be a lazy HAL, it may be stuck starting or still starting). 2025-09-10 14:20:31.720 3214-3251 HidlServiceManagement com.android.networkstack.process I getService: Trying again for android.hardware.tetheroffload.config1.0::IOffloadConfig/default... 2025-09-10 14:20:31.720 1929-6233 system_server system_server I libdebuggerd_client: started dumping process 1529 2025-09-10 14:20:31.721 692-6363 libc hwservicemanager W Unable to set property ctl.interface_start to android.hardware.tetheroffload.config1.0::IOffloadConfig/default: error code: 0x20 2025-09-10 14:20:31.722 692-6363 hwservicemanager hwservicemanager I Tried to start android.hardware.tetheroffload.config1.0::IOffloadConfig/default as a lazy service, but was unable to. Usually this happens when a service is not installed, but if the service is intended to be used as a lazy service, then it may be configured incorrectly.日志中提到android.hardware.tetheroffload.config服务启动失败虽不一定是直接原因但这类驱动或 HAL 层的异常往往会导致system_server挂起进而引发连锁反应导致应用 ANR。然后我们找一下TetherOffload HAL与dnsmasq的关系TetherOffload HAL与dnsmasq1. 技术背景为什么需要 TetherOffload在传统的 Android 热点共享模式下数据包的转发路径是客户端 - 手机 Wi-Fi 网卡 - 内核网络协议栈 - 用户空间的 dnsmasq/netd - 内核协议栈 - 移动网络 (LTE/5G)问题所在数据包需要在“内核态”和“用户态”之间来回切换Context Switching。如果手机开启热点且连接设备较多CPU 需要处理大量中断和数据拷贝导致耗电增加、发热严重、带宽受限。2. TetherOffload 的作用TetherOffload全称 Tethering Offload HAL旨在将这些繁重的“数据转发”任务从 CPU 卸载到硬件如基带芯片、网络加速引擎或专门的 SoC 卸载模块上处理。它的核心逻辑只要连接状态和路由规则稳定后续的数据包就不再经过用户空间的软件栈直接由硬件电路在 Wi-Fi 网卡和蜂窝数据网卡之间进行“物理转发”。3. 两者的具体协作与区别特性dnsmasqTetherOffload HAL定位控制平面(Control Plane)数据平面(Data Plane)职责负责 DHCP 分配、DNS 缓存、路由表维护负责实际的数据报文转发、NAT 映射运行层级用户空间 (User Space)内核空间 (Kernel) 硬件驱动存在意义告诉网络“谁是谁去哪儿”告诉硬件“怎么飞速传输数据”协作流程启动阶段dnsmasq或 Android 现在的netd方案首先运行处理 DHCP 请求为连接的设备分配 IP并设置防火墙规则iptables/nftables。配置阶段Android 系统将这些连接信息和转发规则通过TetherOffload HAL下发给底层的硬件驱动。运行阶段一旦连接稳定TetherOffload 激活。此时绝大部分数据流绕过用户空间的 dnsmasq由硬件直接处理只有极少数控制指令或不符合卸载规则的流量才会回退到软件栈处理。4. 总结它们是互补的dnsmasq 是“大脑”负责处理逻辑复杂但频率不高的网络控制任务比如刚连上热点时 IP 怎么发、域名怎么解析。TetherOffload 是“肌肉”负责处理极其枯燥、耗费资源的纯数据流转发任务。简而言之在现代 Android 系统中TetherOffload 极大地降低了对 dnsmasq 处理高并发数据流的依赖。现在的 Android 倾向于让 dnsmasq 只负责轻量级的 IP 分配而将沉重的流量处理交给 TetherOffload 以提升系统性能。如果你的设备关闭了 TetherOffload例如在某些深度定制的系统或极客修改环境下你会明显感觉到热点速度下降且手机发热加剧因为所有的流量压力都回到了 CPU 和软件进程上。可以看出来TetherOffload异常可能就会导致dnsmasq异常四.修复TetherOffload相关内容后由于TetherOffload这块是hal层逻辑所以是其他同事修复的然后我们就看修复后的变化有没有解决问题首先点击界面没有anr看了然后我们看看Perfetto界面的变化如下是修复后的Perfetto界面可以看出来Settings的performCreate:com.android.settings.SubSettings耗时56ms时间大大缩短了不会导致anr然后继续看可以看出来几乎没有dnsmasq进程占用cpu了所以综合分析是TetherOffload异常导致dnsmasq进程一直在疯狂吃cpu导致Settings没法响应了

相关文章:

使用Perfetto进行Settings中网络热点开启后anr分析的整体流程记录

目录 一.背景 二.Perfetto使用流程 阶段一:抓取 Perfetto Trace 文件 1. 指令核心解析 2. 数据源功能详解 (这些是抓取的“维度”) 3. 该指令的作用场景 阶段二:导入并认识 Perfetto UI 面板 1. 致命异常:Duration: (Did not end) 2…...

Linux内核进程创建与调度机制详解

Linux内核进程创建机制深度解析:从fork到进程调度1. 进程创建概述在Linux操作系统中,进程创建是通过fork系统调用实现的。fork系统调用会创建一个与父进程几乎完全相同的子进程,包括代码段、数据段、堆栈等内存空间的复制。本文将深入分析Lin…...

为什么顶尖量化团队已弃用Pandas清洗?Polars 2.0零拷贝字符串正则+Unicode归一化实战(附GitHub千星Benchmark)

第一章:Polars 2.0 大规模数据清洗技巧 2026 最新趋势 Polars 2.0 在 2026 年已全面支持零拷贝流式清洗、原生 Delta Lake 元数据感知与分布式列式校验,成为金融、遥感与实时日志场景中替代 Pandas 的首选引擎。其核心突破在于 LazyFrame 的智能物化策略…...

嵌入式Linux驱动开发核心技术解析

嵌入式Linux驱动工程师面试技术要点解析1. Linux驱动开发核心技术考察1.1 进程同步机制Linux内核提供了多种进程同步机制,包括:信号量(Semaphore):用于控制对共享资源的访问互斥锁(Mutex)&#…...

OpenClaw任务编排:GLM-4.7-Flash复杂流程设计

OpenClaw任务编排:GLM-4.7-Flash复杂流程设计 1. 为什么需要任务编排 去年我接手了一个市场分析项目,需要每周手动收集竞品动态并生成报告。重复性的复制粘贴和格式调整消耗了大量时间,直到发现OpenClaw可以通过编排GLM-4.7-Flash模型实现全…...

51单片机项目避坑:用ADC0804读PT100信号,你的滤波和标度变换做对了吗?(附源码分析)

51单片机PT100温度检测实战:从ADC采样到标度变换的完整设计解析 在工业温度测量领域,PT100凭借其优异的线性度和稳定性成为首选传感器之一。不同于常见的DS18B20数字温度传感器,PT100需要配合精密信号调理电路和AD转换器才能实现准确测量。本…...

自动驾驶、无人机导航都离不开它:卡尔曼滤波在机器人SLAM中的实战调参心得

自动驾驶与无人机导航中的卡尔曼滤波实战:SLAM系统调参进阶指南 卡尔曼滤波算法自1960年问世以来,已成为机器人定位与导航领域不可或缺的核心技术。无论是自动驾驶汽车的精准定位,还是无人机在复杂环境中的自主飞行,亦或是工业机器…...

沈阳装修靠谱的机构

在沈阳装修新家,最怕遇到不靠谱的装修公司——工期拖延、增项不断、工艺粗糙、售后无门。想要省心、放心、安心地完成装修,选择一家经验丰富、工艺扎实、信誉良好的机构至关重要。在众多沈阳装修公司中,沈阳富田装饰装修工程有限公司以其深厚…...

AI 开发实战:给团队定一套能落地的 AI 使用规范

AI 开发实战:给团队定一套能落地的 AI 使用规范 一、为什么团队用了 AI 反而容易更乱? 因为每个人都在各自试: 有人用来写代码有人用来写文档有人用来查错有人输出直接复制上线 如果没有基本规范,效率可能提升了,但风险…...

stm32开发新手福音:告别复杂安装,用快马ai生成带详解的hal库基础代码

作为一名刚接触STM32开发的新手,我最近在尝试用HAL库控制GPIO时遇到了不少麻烦。从下载安装STM32CubeMX到配置工程,每一步都让我这个小白手忙脚乱。直到发现了InsCode(快马)平台,整个过程变得简单多了——不需要自己搭建环境,AI就…...

OpenClaw多模型管理:Qwen3.5-4B-Claude与其他模型的协作方案

OpenClaw多模型管理:Qwen3.5-4B-Claude与其他模型的协作方案 1. 为什么需要多模型协作 去年冬天,当我第一次尝试用OpenClaw自动化处理技术文档时,发现单一模型很难兼顾所有任务场景。有些模型擅长代码生成但逻辑推理薄弱,有些长…...

Imatest SFR模块实战:从ISO 12233测试卡到MTF指标解析

1. Imatest SFR模块入门指南 第一次接触Imatest SFR模块时,我完全被各种专业术语搞懵了。后来在实际项目中反复使用才发现,这其实就是个"相机体检仪"——通过分析ISO 12233测试卡上的斜边,就能给相机镜头做个全面体检。想象一下医生…...

Qt操作Excel避坑指南:为什么我放弃了QAxObject而选择QXlsx?

Qt操作Excel的终极方案:从QAxObject到QXlsx的技术迁移实战 三年前接手一个工业数据采集项目时,我遇到了职业生涯中最棘手的Excel导出问题。客户现场同时安装了Office 2016和WPS,导致基于QAxObject开发的报表模块随机崩溃。更糟的是&#xff0…...

基于FDM - EDFM的油气藏地层压力场计算:MATLAB实战

基于有限差分-嵌入式离散裂缝网络(FDM-EDFM)的油气藏地层压力场计算,通过matlab代码实现,可提供理论指导和相关问题,可计算不同裂缝网络的压力分布。在油气藏工程领域,准确计算地层压力场对于理解油藏动态、…...

重庆灌浆料销售厂家怎么联系

在重庆的建筑工程领域,灌浆料的应用十分广泛。然而,众多重庆灌浆料厂家的市场状况究竟如何?又存在哪些痛点呢?市场现状:鱼龙混杂目前,重庆灌浆料市场厂家众多,但质量参差不齐。行业权威报告显示…...

实战指南:基于快马生成电商订单自动化n8n工作流,无缝衔接shopify与crm

实战指南:基于快马生成电商订单自动化n8n工作流,无缝衔接shopify与crm 最近在帮朋友优化他们电商业务的后台流程,发现手动处理订单实在太费时间了。特别是遇到大促期间,订单量暴增,人工操作不仅效率低还容易出错。于是…...

变压器绕组类型 | 高频变压器绕制要点

注:本文为 “变压器绕制” 相关合辑。 英文引文,机翻未校。 如有内容异常,请看原文。 图片清晰度受引文原图所限。 变压器绕组类型:圆筒式、螺旋式、交叉式与饼式绕组 Types of Transformer Windings: Cylindrical, Helical, Cro…...

告别重复造轮子,用快马AI一键生成高复用登录组件提升效率

在开发官网登录入口时,我们常常需要重复处理用户认证、表单验证、状态管理等基础逻辑。这些工作虽然不复杂,但每次从零开始确实会消耗不少时间。最近我发现用InsCode(快马)平台可以快速生成高质量的登录组件,大大提升了开发效率。 组件功能设…...

Windows下OpenClaw安装指南:快速对接百川2-13B量化模型

Windows下OpenClaw安装指南:快速对接百川2-13B量化模型 1. 为什么选择OpenClaw百川2-13B组合 去年我在处理个人知识管理时,发现每天要重复执行大量机械操作:整理网页资料、归档PDF、生成日报。直到遇见OpenClaw这个能像人类一样操作电脑的A…...

从防火墙到AI:企业级网络异常检测方案选型指南(2024最新版)

从防火墙到AI:企业级网络异常检测方案选型指南(2024最新版) 当某跨国零售企业遭遇持续3天的DDoS攻击导致线上业务瘫痪时,技术团队发现传统防火墙规则库已48小时未更新;而当某金融机构因AI模型误判正常促销流量为异常导…...

解锁Ghidra:面向逆向工程师的二进制分析工具指南

解锁Ghidra:面向逆向工程师的二进制分析工具指南 【免费下载链接】ghidra_installer Helper scripts to set up OpenJDK 11 and scale Ghidra for 4K on Ubuntu 18.04 / 18.10 项目地址: https://gitcode.com/gh_mirrors/gh/ghidra_installer 剖析Ghidra核心…...

想入行5G网络优化工程师?这6个求职陷阱你必须知道

5G网络优化工程师由于其入职门槛低,需求高,成为了不少想转行的人关注的岗位。 但对于刚入行的小白来说,求职路上往往布满陷阱。 作为一名行业接触过一些内幕的过来人,总结了6条找工作的核心建议,希望能帮大家少走弯路…...

别再瞎猜了!YOLOv8 模型缩放(width_multiple)与通道计算(c1,c2)的完整逻辑

YOLOv8模型通道计算与宽度系数的工程化实践指南 在移动端部署YOLOv8模型时,许多工程师会遇到一个典型困境:明明按照官方文档调整了width_multiple参数,却发现模型要么计算量超出预期,要么精度断崖式下跌。这背后其实隐藏着YOLOv8通…...

保姆级教程:用Docker Compose一键部署Calibre-Web,再也不用担心电子书管理了

零基础打造个人电子书库:Docker Compose全栈部署Calibre-Web实战指南 在数字阅读时代,如何高效管理日益增长的电子书资源成为许多读者的痛点。传统文件管理方式难以满足多设备同步、元数据整理和阅读进度跟踪等需求,而Calibre-Web正是为解决这…...

C# 操作XML

https://blog.csdn.net/2609_95039045/article/details/157469812?fromshareblogdetail&sharetypeblogdetail&sharerId157469812&sharereferPC&sharesourcem0_68206177&sharefromfrom_link 这个写的好 https://blog.csdn.net/lizhenxiqnmlgb/article/det…...

OpenClaw日志分析:QwQ-32B任务执行效率监控

OpenClaw日志分析:QwQ-32B任务执行效率监控 1. 为什么需要监控OpenClaw任务执行效率 去年冬天,我部署了一个自动整理会议纪要的OpenClaw工作流。起初运行得很顺利,直到某天早上发现它漏掉了三场重要会议的记录。检查日志才发现,…...

STM32F103 Bootloader跳转失败?别急着怀疑Boot,先检查你的裸机APP中断向量表

STM32F103 Bootloader跳转失败?别急着怀疑Boot,先检查你的裸机APP中断向量表 当你的STM32F103项目采用HAL库Bootloader搭配裸机应用程序(APP)时,如果遇到Bootloader能正常启动HAL版本的APP却无法跳转裸机APP的情况&…...

技术萨满祭典:给数据中心献祭机械硬盘

一、仪式的缘起:当测试工程师遇见数据之灵在数字文明的殿堂中,数据中心是承载万物之灵的圣地。而软件测试从业者,正是穿梭于代码与硬件之间的现代萨满。当机械硬盘(HDD)在SSD洪流中逐渐退居幕后,这场为老旧…...

基于PLC的智能饲喂系统设计:开启现代养殖自动化新篇章

基于PLC的智能饲喂系统设计 本设计包括设计报告,任务书,模拟工程仿真。本设计的制作智能饲喂是现代物流系统的重要组成部分,是代替人工饲喂的可行性计划,由自动控制与管理系统、配料系统、送料系统、自动统计系统、触摸屏监控系统…...

如何智能检测微信单向好友?WechatRealFriends全方位解决方案

如何智能检测微信单向好友?WechatRealFriends全方位解决方案 【免费下载链接】WechatRealFriends 微信好友关系一键检测,基于微信ipad协议,看看有没有朋友偷偷删掉或者拉黑你 项目地址: https://gitcode.com/gh_mirrors/we/WechatRealFrien…...