iphone:使用NSURLConnection随机EXC_BAD_ACCESS

时间:2010-09-15 12:16:12

标签: iphone nsurlconnection exc-bad-access

我有时会收到关于使用NSURLConnection的EXC_BAD_ACCESS的崩溃报告(根据崩溃报告,我猜它是关于NSURLConnection)。

我在StackOverflow上发现了一个同样类型的报告但没有任何帮助的问题:/(NSURLConnection causes bad access crash);我尝试使用NSZombieEnabled运行应用程序,但因为这个问题真的是“随机”我在运行NSZombieEnabled时从未设法得到它:/

有人提示吗?

非常感谢:)

这是一个支持:

Thread 3 Crashed:
0   libobjc.A.dylib                0x0000286c objc_msgSend + 16
1   CoreFoundation                 0x0000325c CFEqual + 92
2   CoreFoundation                 0x000b081c __CFBasicHashStandardEquateKeys + 12
3   CoreFoundation                 0x000b2578 ___CFBasicHashFindBucket_Linear + 216
4   CoreFoundation                 0x00002ff8 CFBasicHashFindBucket + 220
5   CoreFoundation                 0x00002ec6 CFDictionaryGetValue + 50
6   CFNetwork                      0x0005853a HTTPMessage::copyConstantHeaderFieldValue(unsigned int) const + 26
7   CFNetwork                      0x00090024 URLRequest::copyConstantHeaderFieldValue(unsigned int) const + 20
8   CFNetwork                      0x0008ce0e HTTPProtocol::getCacheStoragePolicy(__CFHTTPMessage*) + 158
9   CFNetwork                      0x0008e6c8 HTTPProtocol::updateForHeader(__CFHTTPMessage*) + 492
10  CFNetwork                      0x0008f73c HTTPProtocol::performHeaderRead() + 368
11  CFNetwork                      0x0008fbea HTTPProtocol::httpReadStreamEvent(unsigned long) + 110
12  CFNetwork                      0x0008fd34 HTTPProtocol::_httpReadStreamCB(__CFReadStream*, unsigned long, void*) + 4
13  CoreFoundation                 0x0004985e _signalEventSync + 70
14  CoreFoundation                 0x000497f2 _cfstream_shared_signalEventSync + 198
15  CoreFoundation                 0x00071a86 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 6
16  CoreFoundation                 0x000736ac __CFRunLoopDoSources0 + 188
17  CoreFoundation                 0x00074504 __CFRunLoopRun + 224
18  CoreFoundation                 0x0001d8e4 CFRunLoopRunSpecific + 224
19  CoreFoundation                 0x0001d7ec CFRunLoopRunInMode + 52
20  Foundation                     0x0003b71e +[NSURLConnection(NSURLConnectionReallyInternal) _resourceLoadLoop:] + 206
21  Foundation                     0x0000bc96 -[NSThread main] + 38
22  Foundation                     0x000909da __NSThread__main__ + 966
23  libSystem.B.dylib              0x0007a986 _pthread_start + 242
24  libSystem.B.dylib              0x000700e4 thread_start + 0

更新

我终于设法在NSZombieEnabled启用时收到错误...但它没有多大帮助:/

这是回溯:

[Switching to thread 13059]
Program received signal:  “EXC_BAD_ACCESS”.
[Switching to thread 13059]
(gdb) bt
#0  0x3090ce9c in CFDictionaryGetValue ()
#1  0x35233540 in HTTPMessage::copyConstantHeaderFieldValue ()
#2  0x3526b02a in URLRequest::copyConstantHeaderFieldValue ()
#3  0x35267e14 in HTTPProtocol::getCacheStoragePolicy ()
#4  0x352693e2 in HTTPProtocol::attemptToCacheMovedPermanently ()
#5  0x3526a6c8 in HTTPProtocol::performHeaderRead ()
#6  0x3526abf0 in HTTPProtocol::httpReadStreamEvent ()
#7  0x3526ad3a in HTTPProtocol::_httpReadStreamCB ()
#8  0x30953864 in _signalEventSync ()
#9  0x309537f8 in _cfstream_shared_signalEventSync ()
#10 0x3097ba8c in __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ ()
#11 0x3097d6b2 in __CFRunLoopDoSources0 ()
#12 0x3097e50a in __CFRunLoopRun ()
#13 0x309278ea in CFRunLoopRunSpecific ()
#14 0x309277f2 in CFRunLoopRunInMode ()
#15 0x3148b724 in +[NSURLConnection(NSURLConnectionReallyInternal) _resourceLoadLoop:] ()
#16 0x3145bc9c in -[NSThread main] ()
#17 0x314e09e0 in __NSThread__main__ ()
#18 0x3129298c in _pthread_start ()
#19 0x312880ec in thread_start ()
(gdb) 

2 个答案:

答案 0 :(得分:3)

我不确定是否有足够的信息可以提供很多帮助: - (

首先,坚持使用NSZombie - 我确信你会及时实现它。确保检查控制台输出,nszombie抛出的异常很可能会被捕获并在某处被忽略。

除此之外,只需仔细检查你用内存做的一切。确保请求在被释放之前被取消,您永远不会意外地用另一个请求覆盖指向正在运行的请求的指针,请确保您没有过度释放您传递给请求的任何对象。

可能会或可能不会解决您的问题的最后一个建议是尝试ASIHTTPRequest:

http://allseeing-i.com/ASIHTTPRequest/

它可以完成NSURLConnection可以做的所有事情(以及其他许多有用的东西),如果你仍然崩溃,你至少会拥有源代码,这样你就可以获得有关出错的更多信息。

答案 1 :(得分:3)

好的,我找到了解决方案/问题。

我的代码还可以,问题的根源是我试图使用这些NSURLConnections从我的网站上获取图像......但我们的搜索引擎优化人员更改了图片网址,因此我重定向了请求。

NSURLConnection不喜欢重定向的请求。

感谢您的帮助!