我有时会收到关于使用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)
答案 0 :(得分:3)
我不确定是否有足够的信息可以提供很多帮助: - (
首先,坚持使用NSZombie - 我确信你会及时实现它。确保检查控制台输出,nszombie抛出的异常很可能会被捕获并在某处被忽略。
除此之外,只需仔细检查你用内存做的一切。确保请求在被释放之前被取消,您永远不会意外地用另一个请求覆盖指向正在运行的请求的指针,请确保您没有过度释放您传递给请求的任何对象。
可能会或可能不会解决您的问题的最后一个建议是尝试ASIHTTPRequest:
http://allseeing-i.com/ASIHTTPRequest/
它可以完成NSURLConnection可以做的所有事情(以及其他许多有用的东西),如果你仍然崩溃,你至少会拥有源代码,这样你就可以获得有关出错的更多信息。
答案 1 :(得分:3)
好的,我找到了解决方案/问题。
我的代码还可以,问题的根源是我试图使用这些NSURLConnections从我的网站上获取图像......但我们的搜索引擎优化人员更改了图片网址,因此我重定向了请求。
NSURLConnection不喜欢重定向的请求。
感谢您的帮助!