diff --git a/.obsidian/workspace.json b/.obsidian/workspace.json
index 136a3b2..76d6537 100644
--- a/.obsidian/workspace.json
+++ b/.obsidian/workspace.json
@@ -1,101 +1,59 @@
{
"main": {
- "id": "011c443bd31fa19e",
+ "id": "4a0abd11ab571e56",
"type": "split",
"children": [
{
- "id": "6f5c5cdf13008dbc",
+ "id": "fd78b55dba3842ff",
"type": "tabs",
"children": [
{
- "id": "9a5781991bf94030",
- "type": "leaf",
- "state": {
- "type": "bases",
- "state": {
- "file": "未命名 1.base",
- "viewName": "表格"
- },
- "icon": "lucide-table",
- "title": "未命名 1"
- }
- },
- {
- "id": "25c9f7051aac05b3",
+ "id": "ee62f962fb280c83",
"type": "leaf",
"state": {
"type": "markdown",
"state": {
- "file": "docs/Obsidian笔记体系/Daily/2026-01-13.md",
+ "file": "docs/学习笔记/Android ANR 知识点总结.md",
"mode": "source",
"source": false
},
"icon": "lucide-file",
- "title": "2026-01-13"
- }
- },
- {
- "id": "59894255df52f532",
- "type": "leaf",
- "state": {
- "type": "markdown",
- "state": {
- "file": "docs/Obsidian笔记体系/Projects/知你-调测/知你--调测.md",
- "mode": "source",
- "source": false
- },
- "icon": "lucide-file",
- "title": "知你--调测"
- }
- },
- {
- "id": "c40cc65d2419fc22",
- "type": "leaf",
- "state": {
- "type": "markdown",
- "state": {
- "file": "docs/学习笔记/Android WindowManagerService (WMS) 架构深度解析(第一次提示词).md",
- "mode": "source",
- "source": false
- },
- "icon": "lucide-file",
- "title": "Android WindowManagerService (WMS) 架构深度解析(第一次提示词)"
+ "title": "Android ANR 知识点总结"
}
}
- ],
- "currentTab": 3
+ ]
}
],
"direction": "vertical"
},
"left": {
- "id": "0e065eabdda832e7",
+ "id": "61450059f20f915c",
"type": "split",
"children": [
{
- "id": "2a433fe0f7c72337",
+ "id": "da53592ec51ff7ee",
"type": "tabs",
"children": [
{
- "id": "5b497a77c6d68c73",
+ "id": "c024a2ca8d9509c3",
"type": "leaf",
"state": {
"type": "file-explorer",
"state": {
"sortOrder": "alphabetical",
- "autoReveal": true
+ "autoReveal": false
},
"icon": "lucide-folder-closed",
"title": "文件列表"
}
},
{
- "id": "845d54777fd1c51f",
+ "id": "866dd8c8b5439582",
"type": "leaf",
"state": {
"type": "search",
"state": {
- "query": "path:\"docs/Obsidian笔记体系/Config/\" ",
+ "query": "",
"matchingCase": false,
"explainSearch": false,
"collapseAll": false,
@@ -107,7 +65,7 @@
}
},
{
- "id": "65c02e8e96d3fa35",
+ "id": "fc645278d7fba125",
"type": "leaf",
"state": {
"type": "bookmarks",
@@ -120,23 +78,23 @@
}
],
"direction": "horizontal",
- "width": 457.5
+ "width": 300
},
"right": {
- "id": "1e41a867da6b7f39",
+ "id": "df584a0a293988b8",
"type": "split",
"children": [
{
- "id": "ef77172a3f8f60a0",
+ "id": "44d87fa4a69d7032",
"type": "tabs",
"children": [
{
- "id": "a990ef40768fba24",
+ "id": "6c4b61ba760eecc8",
"type": "leaf",
"state": {
"type": "backlink",
"state": {
- "file": "docs/Obsidian/2026-01-05 个人文档管理.md",
+ "file": "docs/学习笔记/Android ANR 知识点总结.md",
"collapseAll": false,
"extraContext": false,
"sortOrder": "alphabetical",
@@ -146,25 +104,25 @@
"unlinkedCollapsed": true
},
"icon": "links-coming-in",
- "title": "2026-01-05 个人文档管理 的反向链接列表"
+ "title": "Android ANR 知识点总结 的反向链接列表"
}
},
{
- "id": "2a4816e9de5c79b1",
+ "id": "5f6ecdb98efa5aaa",
"type": "leaf",
"state": {
"type": "outgoing-link",
"state": {
- "file": "docs/Obsidian/2026-01-05 个人文档管理.md",
+ "file": "docs/学习笔记/Android ANR 知识点总结.md",
"linksCollapsed": false,
"unlinkedCollapsed": true
},
"icon": "links-going-out",
- "title": "2026-01-05 个人文档管理 的出链列表"
+ "title": "Android ANR 知识点总结 的出链列表"
}
},
{
- "id": "266c7e7083cb214c",
+ "id": "42daa9caba41cac7",
"type": "leaf",
"state": {
"type": "tag",
@@ -179,7 +137,7 @@
}
},
{
- "id": "f88882a46f03096a",
+ "id": "994bca394167d46e",
"type": "leaf",
"state": {
"type": "all-properties",
@@ -193,18 +151,18 @@
}
},
{
- "id": "9abea599d31b90b9",
+ "id": "e6d6c4e1986fdcf3",
"type": "leaf",
"state": {
"type": "outline",
"state": {
- "file": "docs/Obsidian/2026-01-05 个人文档管理.md",
+ "file": "docs/学习笔记/Android ANR 知识点总结.md",
"followCursor": false,
"showSearch": false,
"searchQuery": ""
},
"icon": "lucide-list",
- "title": "2026-01-05 个人文档管理 的大纲"
+ "title": "Android ANR 知识点总结 的大纲"
}
}
]
@@ -216,62 +174,31 @@
},
"left-ribbon": {
"hiddenItems": {
- "bases:新建数据库": false,
"switcher:打开快速切换": false,
"graph:查看关系图谱": false,
"canvas:新建白板": false,
"daily-notes:打开/创建今天的日记": false,
"templates:插入模板": false,
- "command-palette:打开命令面板": false
+ "command-palette:打开命令面板": false,
+ "bases:新建数据库": false
}
},
- "active": "c40cc65d2419fc22",
+ "active": "ee62f962fb280c83",
"lastOpenFiles": [
- "docs/学习笔记/Android WindowManagerService核心原理深度解析(专家第二次提示词).md",
- "docs/学习笔记/Android性能分析标准化操作手册.md",
- "docs/学习笔记/Android游戏整机性能卡顿与丢帧根因分析与优化指南.md",
- "docs/学习笔记/Android整机性能分析与问题定位实战指南.md",
- "docs/学习笔记/DevOps学习.md",
- "docs/cursor/cursor使用技巧.md",
- "docs/Obsidian/高频命令.md",
- "docs/cursor/cursor.md",
- "docs/Obsidian笔记体系/Projects/聊天平台/测试用例.md",
- "docs/Obsidian笔记体系/Projects/聊天平台/知你客服 6 号(检索增强记忆).md",
- "docs/Obsidian笔记体系/Projects/聊天平台/聊天模型记忆解解方案.md",
- "docs/Obsidian笔记体系/Projects/聊天平台/未命名.md",
- "docs/Obsidian笔记体系/Projects/聊天平台/知你客服5号的设计.md",
- "docs/Obsidian笔记体系/Projects/聊天平台/agent智能体性能调测.md",
- "docs/Obsidian笔记体系/Projects/聊天平台/接入方式.md",
- "docs/Obsidian笔记体系/Projects/聊天平台/聊天平台.md",
- "docs/adb调试命令/adb常用命令.md",
- "docs/Obsidian笔记体系/Projects/聊天平台/app.md",
- "docs/Obsidian笔记体系/Projects/聊天平台/数据库配置.md",
- "docs/Obsidian笔记体系/Projects/saars开发/数据库配置.md",
- "docs/Obsidian笔记体系/Projects/saars开发/aiapply/智能配置助手功能已完成.md",
- "docs/Obsidian笔记体系/Projects/saars开发/aiapply/聊天智能机器人(苏苏).md",
- "docs/Obsidian笔记体系/Projects/saars开发/aiapply/电商系统用户订单处理流程设计方案.md",
- "docs/Obsidian笔记体系/Projects/saars开发/aiapply/个人简历.md",
- "docs/Obsidian笔记体系/Projects/saars开发/aiapply/# 创建Agent经验总结.md",
- "docs/Obsidian笔记体系/Projects/aitsc/ai提示词常用命令.md",
- "docs/Obsidian笔记体系/Projects/聊天平台",
- "docs/Obsidian笔记体系/Projects/aitsc",
- "未命名 1.base",
- "docs/Obsidian笔记体系/Projects/提示词大师",
- "docs/学习笔记/产品经理",
- "Pasted image 20260129111501.png",
- "Pasted image 20260129111451.png",
- "Pasted image 20260129111437.png",
- "Pasted image 20260129111431.png",
- "Pasted image 20260129111423.png",
- "Pasted image 20260129111418.png",
- "Pasted image 20260129111414.png",
- "Pasted image 20260129111408.png",
- "Pasted image 20260129111404.png",
- "Pasted image 20260129111354.png",
- "docs/产品经理",
- "docs/Obsidian笔记体系/Projects/女童生长激素项目",
- "docs/学习笔记/php",
- "docs/cursor/php",
- "com.xiaomi.appstore.appclaim.signature.verification.apk"
+ "docs/Obsidian笔记体系/Projects/女童生长激素项目/后台管理网址.md",
+ "docs/学习笔记/Android ANR 知识点总结.md",
+ "docs/Obsidian笔记体系/Projects/女童生长激素项目/ssl证书申请.md",
+ "docs/Obsidian笔记体系/Projects/女童生长激素项目/项目目录位置.md",
+ "docs/Obsidian笔记体系/Projects/女童生长激素项目/使用系统nginx.md",
+ "docs/Obsidian笔记体系/Projects/女童生长激素项目/生长激素缺乏预测模型项目需求文档.md",
+ "docs/Obsidian笔记体系/Projects/女童生长激素项目/配置完成.md",
+ "docs/Obsidian笔记体系/Projects/女童生长激素项目/宝塔nginx和系统nginx对比分析.md",
+ "docs/Obsidian笔记体系/Projects/女童生长激素项目/宝塔面板.md",
+ "docs/学习笔记/龙虾能力.md",
+ "docs/龙虾openclaw/git同步与上传规范.md",
+ "docs/龙虾openclaw",
+ "docs/龙虾",
+ "docs/新建文件夹",
+ "docs/学习笔记/龙虾配置.md"
]
}
\ No newline at end of file
diff --git a/docs/学习笔记/Android ANR 知识点总结.md b/docs/学习笔记/Android ANR 知识点总结.md
new file mode 100644
index 0000000..0867e9c
--- /dev/null
+++ b/docs/学习笔记/Android ANR 知识点总结.md
@@ -0,0 +1,162 @@
+## 1. 什么是 ANR
+
+ANR 全称:**Application Not Responding**,即**应用程序无响应**。
+
+## 2. 触发条件
+
+1. 只有 ** 主线程(UI 线程)** 才会产生 ANR。
+2. 必须发生输入事件或特定组件操作:
+
+ - 按键、触屏等输入事件
+ - `BroadcastReceiver` 生命周期回调
+ - `Service` 生命周期回调
+
+3. 事件响应超时,不同场景超时时间不同。
+
+### 2.1 各场景超时时间
+
+- **Activity 输入事件 / 生命周期**:主线程 5s 内未处理完毕
+- **BroadcastReceiver#onReceive()**:主线程 10s 内未处理完毕
+- **Service 生命周期**:主线程 20s 内未处理完毕
+
+## 3. ANR 根本原因
+
+### 3.1 主线程执行耗时操作
+
+典型场景:
+
+- 耗时网络访问
+- 大量数据读写、数据库操作
+- 硬件操作(如 Camera)
+- 多线程被 Binder 对端 block
+- 主线程调用 `Thread.join()`/`sleep()`/`wait()`、等待线程锁
+- Service Binder 数量达上限,无法与 System Server 通信
+- System Server 中 WatchDog 导致 ANR、Service 繁忙超时
+
+### 3.2 非主线程导致
+
+非主线程持有锁,导致主线程等待锁超时 / 无限等待,最终触发 ANR。
+
+### 3.3 其他进程 / 系统资源问题
+
+- 其他进程占用 CPU,本进程得不到时间片
+- 内存泄漏导致频繁 Full GC,CPU 占用飙升
+- 内存吃紧、系统频繁 coredump
+
+> CPU 利用率说明:
+>
+> - 前台进程 ≤ 95%,后台进程 ≤ 5%(无前台时可超)
+> - `RUNNABLE` 线程不一定耗 CPU
+> - `TIMED_WAITING`/`WAITING` 线程不耗 CPU
+> - I/O 操作本身不怎么耗 CPU
+
+> 注意:
+>
+> “内存泄露” 可能是真实泄漏点,也可能是堆内存占用过大、内存吃紧,间接导致 ANR/CPU 过高。
+
+## 4. ANR 类型及日志关键字
+
+表格
+
+|ANR 类型|超时时间|Logcat 关键字|
+|---|---|---|
+|InputDispatching Timeout|5s|`Input event dispatching timed out`|
+|BroadcastTimeout|前台 10s
后台 60s|`Timeout of broadcast BroadcastRecord`|
+|ServiceTimeout|前台 20s
后台 200s|`Timeout executing service`|
+|ContentProviderTimeout|10s|`timeout publishing content providers`|
+
+## 5. ANR 定位方法
+
+入手点:ANR 前后日志 + `/data/anr/traces.txt`
+
+### 5.1 日志分析
+
+1. 搜索 `ANR in`:定位发生 ANR 的进程
+2. 搜索 `ActivityManager:CPU usage from`:判断是否 CPU 过高
+
+### 5.2 traces.txt 分析
+
+1. 搜索 `held by tid=`:排查死锁
+2. 查看 `stackSize=`:判断是否内存问题
+
+### 5.3 整体分析步骤
+
+1. 确定 ANR 时间点
+
+ - 关键字:`anr in`、`blocked`、`blockMonitor`、`freezedector`
+ - 获取:版本号、PID、是否前台、页面、温度、频点、ANR 类型
+
+2. 根据 ANR 类型回溯对应时间段日志
+
+ - 查找 `Subject` / `Reason`
+
+3. 分析 ANR 堆栈
+
+ - 查找 `sysTid=线程号`
+ - 状态为 `block`/`timeout` 一般为真实问题堆栈
+
+
+### 5.4 核心分析思路
+
+1. **查看 CPU 负载**
+
+ - user:用户态
+ - kernel:内核态
+ - iowait:IO 等待
+ - faults:内存缺页
+
+2. **查看主线程状态**
+
+ - `Native`:正常空闲,等待消息
+ - `Runnable`:主线程执行耗时操作
+ - `Blocked`:主线程被锁阻塞,可查 `waiting to lock...held by thread`
+
+3. **其他应用抢占 CPU**
+
+ 日志会显示高占比包名,CPU 上限 = 核心数 × 100%
+4. **系统服务 / Binder 问题**
+
+ 搜索:`BinderProxy.transactNative`
+
+ 可能原因:Binder 超时、Binder 资源耗尽
+5. **内存紧张导致 ANR**
+
+ - 查看 ANR 前空闲内存
+
+ - 4G 及以下:阈值约 350M
+ - 4G 以上:阈值约 450M
+
+ - 查看 `trimMemory` 调用(level 越大内存越紧张:5/10/20/40/60/80)
+
+
+## 6. 典型示例
+
+1. 主线程与子线程互锁导致 ANR
+2. Android 系统库崩溃(如 `libweexcore.so` 等)
+3. `nativePollOnce` 阻塞
+4. Binder 对端阻塞(如第三方推送 SDK)
+
+## 7. 非应用自身导致的 ANR
+
+1. **热限频**
+
+ - 温度 > 41℃
+ - 大核频点 < 1.8GHz 且跑满
+
+2. **Monkey 异常场景**
+
+ - 焦点不在当前应用 / 页面已销毁,仍分发输入事件
+ - 不属于 App 代码问题
+
+
+## 8. ANR 根本原因分类总结
+
+表格
+
+|原因类别|具体表现|
+|---|---|
+|主线程自身问题|主线程执行耗时操作、死循环、复杂计算、同步 IO / 网络|
+|线程间竞争|主线程等待子线程锁、死锁、子线程崩溃导致主线程无限等待|
+|CPU 被抢占|其他进程占满 CPU、频繁 GC|
+|系统资源瓶颈|内存紧张、GC 频繁、系统服务繁忙、Binder 耗尽|
+|系统 / 环境问题|热限频、Monkey 异常、系统服务超时|
\ No newline at end of file