作者fatandy567 (Technofreak)
看板EE_DSnP
标题[问题] HW4 ***glibc detected***
时间Thu Nov 22 23:29:25 2012
我的程式跑do4 的测资,跑到"mtn 1 -a 0"这行,程式会在 MTNew 指令中的
if(CmdExec::lexOptions(option,options)==false) crash
错误讯息是:
***glibc detected*** malloc() memory corruption ......
然号跑出trace back之类的一大多位址
这是什麽问题??
--
※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 140.112.217.12
1F:推 ric2k1:建议用一个最小而会造成 crash 的 dofile,跑 debugger慢慢 11/22 23:41
2F:→ ric2k1:trace 你的 code. 应该是不知道在什麽地方你把 memory 11/22 23:42
3F:→ ric2k1:corrupt 掉了... 可能也没有比用 debugger 更好的办法... 11/22 23:43
4F:→ fatandy567:可是我do1~3都正确耶?? 11/22 23:50
5F:推 ric2k1:可是 do4 会 crash 还是表示你的程式有 bug... 11/23 00:04
6F:→ ric2k1:要相信 crash 事出必有因 11/23 00:05
7F:→ ric2k1:然後想: 还好不是等到助教那边才被发现 crash... 11/23 00:06
8F:推 ypf791:面对这种 bug 只能把自己的程式逻辑重想一遍又一遍.... 11/23 00:18
9F:推 ric2k1:恩,用 debugger 把变数 print 出来绝对会有帮助的 11/23 00:31
10F:→ ric2k1:另外,这种 memory corruption 通常是某个变数的值在莫名 11/23 00:32
11F:→ ric2k1:奇妙的地方被改掉了。由於变数不在它的 domain 就无法print 11/23 00:32
12F:→ ric2k1:可以把 "绝对记忆体位置" 的内容 display 出来. 11/23 00:33
13F:→ ric2k1:像是 display *((MemTestObj *) 0x7f00b8c) 之类的 11/23 00:34
14F:推 gamerred:感觉像是double delete的问题 然後回报的位置通常很奇怪 11/23 00:38
15F:推 ric2k1:double delete 应该会说 "doubly freed error..." 之类的 11/23 00:45
16F:→ fatandy567:果然是自己耍蠢了,memblock的getmem应该是先return再 11/24 00:24
17F:→ fatandy567:移动指标,结果果先移动再输出,难怪会crash.... 11/24 00:24
18F:→ fatandy567:谢谢老师和大家 11/24 00:25
19F:推 ric2k1:Great! 11/24 00:57
20F:推 stanleysu:我也跟你有同样的crash耶,不过我是错在rn在remainsize 11/24 01:45
21F:→ stanleysu:太小的时候会变成奇怪的值 11/24 01:45
22F:→ fatandy567:楼上会不会是size_t不含负的关系,要不要转成int试试? 11/24 11:19