今天组里的一个算法里面出现很严重的内存泄漏问题,通过一些手段解决了。记录一下。
背景
- 对于C语言的内存泄漏来讲,一般就是alloc出来的对象没有free。一般而言,推荐的写法就是自己alloc,自己free。在这段代码里面出现了一些不好的C语言的写法,导致内存的alloc和free没有出现对称,这是代码作者的习惯导致的。
- 代码里面出现了结构体里面alloc新对象的写法,而且非常的隐蔽,导致查找工作很困难。
工具包
- xcode
以前只用xcode做过一些ios项目的开发,因为oc或者swift有着比较完善的ARC,所以都没主要到还有内存泄漏检测工具。
解决方式
- 使用xcode打开项目
-
command+i
打开Instruments
-
选择Leaks
里面有内存分配以及内存泄漏情况,可用于内存分析和优化参照。
- 点击红色开始运行程序
如果没有泄漏,内存会是平缓的一根线。如果是泄漏就是一条向上走的线,这个和Android Studio提供的内存分析工具很像。可以看出我这里是有内存泄漏的。
-
分享没存泄漏位置,定位代码
右边会有一个调用栈,就可以定位到内存泄漏的位置了,进而就可以很快解决了。
背景
- 不管是什么语言,只要一不小心就会出现内存泄漏问题。不过对于有GC的语言来讲相对安全,但同样的,出现了也相对不好解决。解决这类问题的核心就是找到内存泄漏的位置,一个靠谱的内存分析工具就非常重要了。
推荐几个常用的内存分析工具:- top 指令。 在Linux或者mac上面可以快速定位泄漏的程序和程度
- Golang 使用 内置的runtime/pprof即可。
deno
就是用的这个。 - Android 使用Android Studio可以做一定的内存分析。使用
Memory Profiler
工具加上LeakCanary
是最好的选择。 - Node.js 使用
heapdump
+devtool
- 前端js 使用chrome内存分析工具即可。
- Java 主要是对垃圾回收和内存做分析。使用
JConsole
可是看见内存情况,再加上JVM自带的一些指令,就可以很好的看见内存的分配和回收情况,然后做进一步优化。
这几块每一个都有很大的含金量,希望能带来一些思考,避免每天只写业务代码,忽视了程序内在的执行。毕竟优化比做功能难太多。