如何找出哪个数组/对象/ etc是堆栈内存中最贪吃的用户?
注意:下面是问题的原始上下文。从那时起,我意识到我对堆栈的工作方式存在严重的误解。
我有一个以段错误结束的错误程序。段错误是由一个变量被蓝色的非敏感值覆盖引起的......该变量位于堆栈内存中。
因此我的理解是,在程序的某个其他位置有堆栈内存溢出,这会破坏下一个堆栈内存缓冲区开头的变量值。
但是,在遇到段错误之前,valgrind没有显示任何错误/警告(当使用--leak-checks = yes启动时)。
因此,解决方案是找到哪些对象/数组/等使用大部分堆栈内存并将它们移动到堆内存。
答案 0 :(得分:1)
如果您在Mac上进行开发,那么您可以使用Instruments,它有一个内存分析器,可以告诉您内存分配的位置以及基于此的聚合。
否则,您可以使用valgrind的Massif工具
如果您使用的是Mac,则可以使用乐器。否则,您可以尝试使用Massif。来自Massif manual的示例输出:
--------------------------------------------------------------------------------
n time(B) total(B) useful-heap(B) extra-heap(B) stacks(B)
--------------------------------------------------------------------------------
10 10,080 10,080 10,000 80 0
11 12,088 12,088 12,000 88 0
12 16,096 16,096 16,000 96 0
13 20,104 20,104 20,000 104 0
14 20,104 20,104 20,000 104 0
99.48% (20,000B) (heap allocation functions) malloc/new/new[], --alloc-fns, etc.
->49.74% (10,000B) 0x804841A: main (example.c:20)
|
->39.79% (8,000B) 0x80483C2: g (example.c:5)
| ->19.90% (4,000B) 0x80483E2: f (example.c:11)
| | ->19.90% (4,000B) 0x8048431: main (example.c:23)
| |
| ->19.90% (4,000B) 0x8048436: main (example.c:25)
|
->09.95% (2,000B) 0x80483DA: f (example.c:10)
->09.95% (2,000B) 0x8048431: main (example.c:23)
答案 1 :(得分:0)
尝试使用观察点来查找写入内存的时间