Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/liangdahong/AMLeaksFinder
A small tool for automatically detecting the [controller, view memory leak] in the project. 一款用于自动检测项目中【控制器内存泄漏,View 内存泄漏】的小工具,支持 ObjC,Swift。
https://github.com/liangdahong/AMLeaksFinder
controller ios leak leaks meaksfinder memory memory-leak mleaksfinder objective-c runtime
Last synced: about 2 months ago
JSON representation
A small tool for automatically detecting the [controller, view memory leak] in the project. 一款用于自动检测项目中【控制器内存泄漏,View 内存泄漏】的小工具,支持 ObjC,Swift。
- Host: GitHub
- URL: https://github.com/liangdahong/AMLeaksFinder
- Owner: liangdahong
- License: mit
- Created: 2020-05-13T02:08:34.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-04-20T17:10:17.000Z (9 months ago)
- Last Synced: 2024-10-31T15:52:55.951Z (3 months ago)
- Topics: controller, ios, leak, leaks, meaksfinder, memory, memory-leak, mleaksfinder, objective-c, runtime
- Language: Objective-C
- Homepage: https://liangdahong.com/2020/06/08/iOS%E4%B8%AD%E5%A6%82%E4%BD%95%E8%87%AA%E5%8A%A8%E7%9B%91%E6%8E%A7%E6%8E%A7%E5%88%B6%E5%99%A8%E5%86%85%E5%AD%98%E6%B3%84%E6%BC%8F/
- Size: 80.4 MB
- Stars: 149
- Watchers: 4
- Forks: 23
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome - AMLeaksFinder - A small tool for automatically detecting the [controller, view memory leak] in the project. 一款用于自动检测项目中【控制器内存泄漏,View 内存泄漏】的小工具,支持 ObjC,Swift。 (OOM-Leaks-Crash / GraphQL)
- awesome - AMLeaksFinder - A small tool for automatically detecting the [controller, view memory leak] in the project. 一款用于自动检测项目中【控制器内存泄漏,View 内存泄漏】的小工具,支持 ObjC,Swift。 (OOM-Leaks-Crash / GraphQL)
README
```js
_ __ __ _ _ _____ _ _
/ \ | \/ | | ___ __ _| | _____| ___(_)_ __ __| | ___ _ __
/ _ \ | |\/| | | / _ \/ _` | |/ / __| |_ | | '_ \ / _` |/ _ \ '__|
/ ___ \| | | | |__| __/ (_| | <\__ \ _| | | | | | (_| | __/ |
/_/ \_\_| |_|_____\___|\__,_|_|\_\___/_| |_|_| |_|\__,_|\___|_|
```
## 介绍
本项目是一款用于自动检测 iOS 项目中【 **`UIView 和 UIViewController 内存泄漏`** 】的工具,只需 `pod 'AMLeaksFinder'` 即可 0 行代码实现自动监控,效果如下,推荐使用 `Cocoapods` 导入,和 [MLeakFinder](https://github.com/Tencent/MLeaksFinder) 的区别可参考 [对比 MLeakFinder](https://github.com/liangdahong/AMLeaksFinder/issues/4) 。
[English 📔](README_EN.md)
## 功能介绍
* [x] 自动监控 **`Controller`** 的泄漏;
* [x] 自动监控 **`View`** 的泄漏;
* [x] 借助 [FBRetainCycleDetector](https://github.com/facebook/FBRetainCycleDetector) 快速排查泄漏原因 【 ⚠️ 只在 `ObjC` 上有效 】;
* [x] 监控到泄漏时支持快速查看泄漏的视图【 **`View`**,**`Controller View`**,**`View 的 root View`** 等】;
* [ ] 更多功能欢迎补充。## Cocoapods
```
pod 'AMLeaksFinder', '2.2.8', :configurations => ['Debug']
```- 如果想查看控制器的强引用链,可导入:Facebook 的 [FBRetainCycleDetector](https://github.com/facebook/FBRetainCycleDetector) 框架即可。
```
pod 'FBRetainCycleDetector', :git => 'https://github.com/facebook/FBRetainCycleDetector.git', :branch => 'main', :configurations => ['Debug']
```## 直接使用
- 请拖拽 `AMLeaksFinder/AMLeaksFinder` 文件夹的全部内容到项目
- 启用 & 关闭 `AMLeaksFinder`
- 打开 `__AUTO_MEMORY_LEAKS_FINDER_ENABLED__` 宏表示启用
- 注释 `__AUTO_MEMORY_LEAKS_FINDER_ENABLED__` 宏表示关闭
- 显示/隐藏 `AMLeaksFinder` 视图
- 发送通知
```ObjectiveC
if (显示UI) {
[NSNotificationCenter.defaultCenter postNotificationName:@"AMLeaksFinderShowUINotification" object:nil];
} else {
[NSNotificationCenter.defaultCenter postNotificationName:@"AMLeaksFinderHideUINotification" object:nil];
}
```
## 数据收集
> 若想收集泄漏相关数据可使用如下 API:
- https://github.com/liangdahong/AMLeaksFinder/blob/master/AMLeaksFinder/AMLeaksFinder.h```
控制器路径变化 AMLeaksFinder.ViewHasLeakVC viewDidDisappear: 2022-04-04 04:21:06 +0000
控制器路径变化 AMHomeVC viewDidAppear: 2022-04-04 04:21:06 +0000
控制器路径变化 AMPresentHasLeakVC viewDidLoad: 2022-04-04 04:21:07 +0000
控制器路径变化 AMPresentHasLeakVC viewDidAppear: 2022-04-04 04:21:07 +0000
控制器路径变化 AMTabBarController viewDidDisappear: 2022-04-04 04:21:07 +0000
控制器路径变化 BMNavigationController viewDidDisappear: 2022-04-04 04:21:07 +0000
控制器路径变化 AMHomeVC viewDidDisappear: 2022-04-04 04:21:07 +0000
控制器路径变化 AMTabBarController viewDidAppear: 2022-04-04 04:21:08 +0000
控制器路径变化 BMNavigationController viewDidAppear: 2022-04-04 04:21:08 +0000
控制器路径变化 AMHomeVC viewDidAppear: 2022-04-04 04:21:08 +0000
控制器路径变化 AMPresentHasLeakVC viewDidDisappear: 2022-04-04 04:21:08 +0000
⚠️👇🏻
视图泄漏: >
视图所在控制器 AMLeaksFinder.ViewHasLeakVC
操作路径:
BMNavigationController(viewDidLoad:) ->
AMTabBarController(viewDidLoad:) ->
AMHomeVC(viewDidLoad:) ->
AMTabBarController(viewDidAppear:) ->
BMNavigationController(viewDidAppear:) ->
AMHomeVC(viewDidAppear:) ->
AMPresentHasLeakVC(viewDidLoad:) ->
AMPresentHasLeakVC(viewDidAppear:) ->
AMTabBarController(viewDidDisappear:) ->
BMNavigationController(viewDidDisappear:) ->
AMHomeVC(viewDidDisappear:) ->
AMTabBarController(viewDidAppear:) ->
BMNavigationController(viewDidAppear:) ->
AMHomeVC(viewDidAppear:) ->
AMPresentHasLeakVC(viewDidDisappear:) ->
AMPresentHasLeakVC(viewDidLoad:) ->
AMPresentHasLeakVC(viewDidAppear:) ->
AMTabBarController(viewDidDisappear:) ->
BMNavigationController(viewDidDisappear:) ->
AMHomeVC(viewDidDisappear:) ->
AMTabBarController(viewDidAppear:) ->
BMNavigationController(viewDidAppear:) ->
AMHomeVC(viewDidAppear:) ->
AMPresentHasLeakVC(viewDidDisappear:) ->
_UIAlertControllerTextFieldViewController(viewDidLoad:) ->
UIAlertController(viewDidLoad:) ->
UIAlertController(viewDidAppear:) ->
UIAlertController(viewDidDisappear:) ->
AMLeaksFinder.ViewHasLeakVC(viewDidLoad:) ->
AMHomeVC(viewDidDisappear:) ->
AMLeaksFinder.ViewHasLeakVC(viewDidAppear:) ->
AMLeaksFinder.ViewHasLeakVC(viewDidDisappear:) ->
AMHomeVC(viewDidAppear:) ->
AMPresentHasLeakVC(viewDidLoad:) ->
AMPresentHasLeakVC(viewDidAppear:) ->
AMTabBarController(viewDidDisappear:) ->
BMNavigationController(viewDidDisappear:) ->
AMHomeVC(viewDidDisappear:) ->
AMTabBarController(viewDidAppear:) ->
BMNavigationController(viewDidAppear:) ->
AMHomeVC(viewDidAppear:) ->
AMPresentHasLeakVC(viewDidDisappear:) ->
⚠️👆🏻
```## 原理分析
- [原理分析](principle.md)
- 数据结构图
- ![数据结构图](https://user-images.githubusercontent.com/12118567/120919021-0bf22e80-c6ea-11eb-8f5f-d3d8c14d4666.jpg)- 项目文件结构
```SWIFT
├── AMLeaksFinder
│ ├── AMLeaksFinder.h
│ ├── AMLeaksFinder.m
│ ├── AMLeaksFinder.bundle
│ │ ├── [email protected]
│ │ ├── [email protected]
│ │ ├── [email protected]
│ │ └── [email protected]
│ ├── Objects
│ │ ├── Controllers
│ │ │ ├── Model
│ │ │ │ ├── AMMemoryLeakDeallocModel.h
│ │ │ │ ├── AMMemoryLeakDeallocModel.m
│ │ │ │ ├── AMMemoryLeakModel.h
│ │ │ │ └── AMMemoryLeakModel.m
│ │ │ ├── NeedDealloc
│ │ │ │ ├── UINavigationController+AMLeaksFinderSwizzleDealloc.m
│ │ │ │ ├── UIPageViewController+AMLeaksFinderSwizzleDealloc.m
│ │ │ │ ├── UISplitViewController+AMLeaksFinderSwizzleDealloc.m
│ │ │ │ ├── UITabBarController+AMLeaksFinderSwizzleDealloc.m
│ │ │ │ ├── UIViewController+AMLeaksFinderSwizzleDealloc.m
│ │ │ │ ├── UIWindow+AMLeaksFinderSwizzleDealloc.m
│ │ │ └── ViewDidLoad
│ │ │ ├── UIViewController+AMLeaksFinderSwizzleViewDidLoad.m
│ │ └── View
│ │ └── Model
│ │ ├── AMViewMemoryLeakDeallocModel.h
│ │ ├── AMViewMemoryLeakDeallocModel.m
│ │ ├── AMViewMemoryLeakModel.h
│ │ └── AMViewMemoryLeakModel.m
│ ├── UI
│ │ ├── AMLeakDataModel.h
│ │ ├── AMLeakDataModel.m
│ │ ├── AMLeakOverviewView.h
│ │ ├── AMLeakOverviewView.m
│ │ ├── AMMemoryLeakView.h
│ │ ├── AMMemoryLeakView.m
│ │ ├── AMMemoryLeakView.xib
│ │ ├── AMSnapedViewViewController.h
│ │ ├── AMSnapedViewViewController.m
│ │ ├── UIViewController+AMLeaksFinderUI.h
│ │ └── UIViewController+AMLeaksFinderUI.m
│ └── Uitis
│ ├── Controller
│ │ ├── UIViewController+AMLeaksFinderTools.h
│ │ └── UIViewController+AMLeaksFinderTools.m
│ └── View
│ ├── UIView+AMLeaksFinderTools.h
│ └── UIView+AMLeaksFinderTools.m
```## 联系
- 欢迎 [Issues](https://github.com/liangdahong/AMLeaksFinder/issues) 和 [Pull Requests](https://github.com/liangdahong/AMLeaksFinder/pulls)
- 也可以添加微信 进群吹水。