- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在努力追踪我的 iPhone 程序中一些难以发现的内存泄漏。我正在对一个应用程序进行快速测试,该应用程序泄漏了一个 NSString 对象,其中包含以下故意 - 不正确的 - 代码:
-(void)applicationDidFinishLaunching:(NSNotification *)notification;
{
NSMutableString *test = [[NSMutableString alloc] init];
[test appendString:@"Testing 1"];
[test appendString:@"\nTesting 2"];
NSLog(@"%@", test);
// Uncomment the following line to release the
// string and clean up your leak.
// [test release], test = nil;
}
在对应用程序的进程 ID 运行泄漏后,我得出以下结论:
sf$ leaks 3951
Process 3951: 9988 nodes malloced for 1260 KB
Process 3951: 3 leaks for 128 total leaked bytes.
Leak: 0x163b50 size=64 instance of 'NSCFDictionary', type ObjC, implemented in Foundation
0xa07e0720 0x01001080 0x0000000a 0x00000010 .~.............
0x0000000a 0x0000000c 0x0000000b 0x00000000 ................
0x00000000 0x00000015 0xa1b1c1d3 0x00163b90 .............;..
0x00163bd0 0x00000000 0x00000000 0x00000000 .;..............
Leak: 0x178190 size=32 string 'Testing 1
Testing 2'
Leak: 0x178210 size=32 instance of 'NSCFString', type ObjC, implemented in CoreFoundation
0xa02e24a0 0x010007ad 0x00178190 0x00000013 .$..............
0x00000020 0x00000200 0x00000000 0x00000000 ...............
现在,我们都知道漏洞在哪里了。这不是这个练习的重点,至少对我来说是这样。我正在尝试识别如何理解此输出。有人告诉我有 3 处泄漏。
它们是位于内存地址 0x163b50、0x178190、0x178210 的对象。根据“泄漏”,它们的实现是在 Apple 框架中,而不是我的代码中。在如下所示的一个简单示例中,查找泄漏并不困难。但是,在具有 500K 行代码的应用程序中,我发现此处泄漏的输出无用。
我做错了什么,我如何理解这个输出以帮助我找到我为清理内存泄漏而编写的代码中的罪魁祸首?
请注意,此线程不应提倡使用 Instruments 或 Clang Static Analyzer。我已经清理了 Clang Static Analyzer 向我报告的所有内存泄漏。 Instruments 对我来说是臃肿的和无信息的。我收到了大量关于泄漏的报告,但堆栈跟踪显示的这些报告都没有返回到我自己的代码——尽管我确定泄漏确实在我的代码中。我想弄清楚如何在此处使用 cmd 行泄漏工具。
谢谢大家。
编辑:即使在取消对清理泄漏的行的注释之后,“泄漏”实用程序的提示甚至比发生泄漏时还要多。 Foundation/Cocoa 是否从这样一个微不足道的例子中泄漏了那么多?这发生在取消注释上面的测试字符串的版本之后:
sf$ leaks 4383
Process 4383: 9890 nodes malloced for 1255 KB
Process 4383: 7 leaks for 560 total leaked bytes.
Leak: 0x163920 size=176 instance of 'NSPathStore2', type ObjC, implemented in Foundation
0xa07e2ae0 0x04f00000 0x0055002f 0x00650073 .*~...../.U.s.e.
0x00730072 0x0073002f 0x002f0066 0x0069004c r.s./.s.f./.L.i.
0x00720062 0x00720061 0x002f0079 0x00700041 b.r.a.r.y./.A.p.
0x006c0070 0x00630069 0x00740061 0x006f0069 p.l.i.c.a.t.i.o.
0x0020006e 0x00750053 0x00700070 0x0072006f n. .S.u.p.p.o.r.
0x002f0074 0x00490053 0x0042004d 0x002f004c t./.S.I.M.B.L./.
0x006c0050 0x00670075 0x006e0069 0x002f0073 P.l.u.g.i.n.s./.
0x00650054 0x006d0072 0x006e0069 0x006c0061 T.e.r.m.i.n.a.l.
...
Leak: 0x163350 size=160 instance of 'NSPathStore2', type ObjC, implemented in Foundation
0xa07e2ae0 0x04a00000 0x0055002f 0x00650073 .*~...../.U.s.e.
0x00730072 0x0073002f 0x002f0066 0x0069004c r.s./.s.f./.L.i.
0x00720062 0x00720061 0x002f0079 0x00700041 b.r.a.r.y./.A.p.
0x006c0070 0x00630069 0x00740061 0x006f0069 p.l.i.c.a.t.i.o.
0x0020006e 0x00750053 0x00700070 0x0072006f n. .S.u.p.p.o.r.
0x002f0074 0x00490053 0x0042004d 0x002f004c t./.S.I.M.B.L./.
0x006c0050 0x00670075 0x006e0069 0x002f0073 P.l.u.g.i.n.s./.
0x00650044 0x0069006c 0x00690063 0x0075006f D.e.l.i.c.i.o.u.
...
Leak: 0x1635a0 size=64 instance of 'NSCFDictionary', type ObjC, implemented in Foundation
0xa07e0720 0x01001080 0x0000000a 0x00000010 .~.............
0x0000000a 0x0000000c 0x0000000b 0x00000000 ................
0x00000000 0x00000015 0xa1b1c1d3 0x001635e0 .............5..
0x00163620 0x00000000 0x00000000 0x00000000 6..............
Leak: 0x163620 size=64
0xa02ed360 0x00160ee0 0x00163700 0xa02efc00 `........7......
0x00000000 0x00000000 0x00163680 0x00000000 .........6......
0x00000000 0x00000000 0x00163660 0xa02ed440 ........`6..@...
0xa02ec1a0 0xa02f0420 0x00000000 0x00163660 .... ./.....`6..
Leak: 0x163680 size=48 instance of 'NSCFString', type ObjC, implemented in CoreFoundation
0xa02e24a0 0x0100078c 0x6d6f6323 0x6c65642e .$......#com.del
0x6f696369 0x61737375 0x69726166 0x6c65442e icioussafari.Del
0x6f696369 0x61537375 0x69726166 0x00000000 iciousSafari....
Leak: 0x163660 size=32 instance of 'NSCFString', type ObjC, implemented in CoreFoundation
0xa02e24a0 0x0200078c 0x6c65440f 0x6f696369 .$.......Delicio
0x61537375 0x69726166 0x00000000 0x00000000 usSafari........
Leak: 0x160ee0 size=16 instance of 'NSCFString', type ObjC, implemented in CoreFoundation
0xa02e24a0 0x0100078c 0x362e3103 0x00000000 .$.......1.6....
最佳答案
您显示的输出中没有堆栈跟踪。您看到的地址是对象自己的地址,而不是函数指针,标点符号旁边的十六进制数字只是数据的十六进制转储。
要找出对象是从哪里分配的,请在泄漏的环境中设置 MallocStackLogging:
% MallocStackLogging=1 leaks …
您可能还想使用 -nocontent 选项,它会抑制十六进制转储。但是,不要一直使用它:有时十六进制转储包含有值(value)的线索。
此外,漏气并不一定告诉您有三处漏气;准确地说,它告诉您有三个泄漏的对象。您展示的故意泄漏只会产生一个泄漏对象,但不同的泄漏(例如在循环或频繁调用的方法中)可能会泄漏许多对象。
编辑:顺便说一句,其中一些泄漏来自 SIMBL 或您的一个或多个 SIMBL 插件。在查找泄漏之前关闭 SIMBL 和任何其他输入管理器 hack。请记住,该代码在您的进程中运行;此外,leaks 并不关心是谁的代码分配或泄漏了内存,只关心它是否泄漏了,因此无论是谁分配或泄漏的,它都会显示泄漏的对象。
关于iphone - 了解用于查找内存泄漏的 'leaks' 命令行实用程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/761077/
我在具有 2CPU 和 3.75GB 内存 (https://aws.amazon.com/ec2/instance-types/) 的 c3.large Amazon EC2 ubuntu 机器上运
我想通过用户空间中的mmap-ing并将地址发送到内核空间从用户空间写入VGA内存(视频内存,而不是缓冲区),我将使用pfn remap将这些mmap-ed地址映射到vga内存(我将通过 lspci
在 Mathematica 中,如果你想让一个函数记住它的值,它在语法上是很轻松的。例如,这是标准示例 - 斐波那契: fib[1] = 1 fib[2] = 1 fib[n_]:= fib[n] =
我读到动态内存是在运行时在堆上分配的,而静态内存是在编译时在堆栈上分配的,因为编译器知道在编译时必须分配多少内存。 考虑以下代码: int n; cin>>n; int a[n]; 如果仅在运行期间读
我是 Python 的新手,但我之前还不知道这一点。我在 for 循环中有一个基本程序,它从站点请求数据并将其保存到文本文件但是当我检查我的任务管理器时,我发现内存使用量只增加了?长时间运行时,这对我
我正在设计一组数学函数并在 CPU 和 GPU(使用 CUDA)版本中实现它们。 其中一些函数基于查找表。大多数表占用 4KB,其中一些占用更多。基于查找表的函数接受一个输入,选择查找表的一两个条目,
读入一个文件,内存被动态分配给一个字符串,文件内容将被放置在这里。这是在函数内部完成的,字符串作为 char **str 传递。 使用 gdb 我发现在行 **(str+i) = fgetc(aFil
我需要证实一个理论。我正在学习 JSP/Java。 在查看了一个现有的应用程序(我没有写)之后,我注意到一些我认为导致我们的性能问题的东西。或者至少是其中的一部分。 它是这样工作的: 1)用户打开搜索
n我想使用memoization缓存某些昂贵操作的结果,这样就不会一遍又一遍地计算它们。 两个memoise和 R.cache适合我的需要。但是,我发现缓存在调用之间并不可靠。 这是一个演示我看到的问
我目前正在分析一些 javascript shell 代码。这是该脚本中的一行: function having() { memory = memory; setTimeout("F0
我有一种情况,我想一次查询数据库,然后再将整个数据缓存在内存中。 我得到了内存中 Elasticsearch 的建议,我用谷歌搜索了它是什么,以及如何在自己的 spring boot 应用程序中实现它
我正在研究 Project Euler (http://projecteuler.net/problem=14) 的第 14 题。我正在尝试使用内存功能,以便将给定数字的序列长度保存为部分结果。我正在
所以,我一直在做 Java 内存/注意力游戏作业。我还没有达到我想要的程度,它只完成了一半,但我确实让 GUI 大部分工作了......直到我尝试向我的框架添加单选按钮。我认为问题可能是因为我将 JF
我一直在尝试使用 Flask-Cache 的 memoize 功能来仅返回 statusTS() 的缓存结果,除非在另一个请求中满足特定条件,然后删除缓存。 但它并没有被删除,并且 Jinja 模板仍
我对如何使用 & 运算符来减少内存感到非常困惑。 我可以回答下面的问题吗? clase C{ function B(&$a){ $this->a = &$a; $thi
在编写代码时,我遇到了一个有趣的问题。 我有一个 PersonPOJO,其 name 作为其 String 成员之一及其 getter 和 setter class PersonPOJO { priv
在此代码中 public class Base { int length, breadth, height; Base(int l, int b, int h) { l
Definition Structure padding is the process of aligning data members of the structure in accordance
在 JavaScript Ninja 的 secret 中,作者提出了以下方案,用于在没有闭包的情况下内存函数结果。他们通过利用函数是对象这一事实并在函数上定义一个属性来存储过去调用函数的结果来实现这
我正在尝试找出 map 消耗的 RAM 量。所以,我做了以下事情;- Map cr = crPair.collectAsMap(); // 200+ entries System.out.printl
我是一名优秀的程序员,十分优秀!