标签:apple round 2.0 调试 ras neu dma class mac
void *objectISA = (JK_EXPECT_F(workAroundMacOSXABIBreakingBug)) ? NULL : *((void **)objectPtr); 好久没启动的项目突然崩在了JSONKit.m中的2599这一行,只给出了EXC_BAD_ACCESS这样的信息,一直以为是JSONKit中有问题,找了好久,很多人说是JSONKit版本太低,需要换成新版本,也有人说访问了僵尸指针等等,自己感觉也是僵尸指针的问题,但是不知道crash的具体位置在哪儿,也很奇怪为什么会crash到了JSONKit中。
盲目找的时候突然发现objectPtr的值是null,好吧,明显是项目代码中传入了空值,打断点,一步步的调试,终于发现了是做数据请求字典转json的时候,字典里带有null的参数,不可变字典是可以存入null值的,可变字典就不一样会在遇到null值的时候自动过滤掉,崩溃的位置定位到了,就好解决问题了,记录一下,以免下次还在JSONKit里盲目的找问题。
记得之前看到过一句话,大致意思是,如果项目crash了,千万不要盲目的更改,然后以为bug会被改掉,这样只会越改越糟。其实所有事情都是这样,bug不会无缘无故的存在,只有找到问题,弄清楚原因,才能完全解决问题。希望自己能谨记这一点,不会存在很奇怪的问题,代码也不会是神经病,一定会有原因的,需要做的是耐心的找问题。
标签:apple round 2.0 调试 ras neu dma class mac
原文地址:http://www.cnblogs.com/MatyLin/p/7843545.html