2010-09-15 81 views
2

随机EXC_BAD_ACCESS我有时会收到关于与NSURLConnection的(我猜它根据崩溃报告是关于NSURLConnection的)一个EXC_BAD_ACCESS崩溃报告。iPhone:与NSURLConnection的

我发现了一个问题在这里StackOverflow上与同类报告,但没有任何帮助有:/(NSURLConnection causes bad access crash);我试着用NSZombieEnabled运行应用程序,但由于这个问题是真的“随机”,我从来没有设法得到它与NSZombieEnabled运行:/

任何人有提示?

感谢很多:)

这里有一个repport:

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

真的很难知道我是否看不到您的代码。在这种情况下,代码检查是最好的,可能是唯一的方法 – vodkhang 2010-09-15 12:20:08

+0

使用源,卢克。 – 2010-09-15 12:26:40

+0

嗯,我不能告诉你的代码,因为我不知道代码的哪一部分可能会导致此错误:/将不得不提供整个项目的来源。再一次,这是非常随机的和崩溃的报告没有那么有用 – Vivi 2010-09-15 12:45:28

回答

3

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

我的代码是好的,问题的根源是,我试图从我的网站使用这些NSURLConnections获取图像......但我们的SEO人更改了图像网址,因此我重定向了请求。

NSURLConnection不太喜欢重定向的请求。

感谢您的帮助!

3

我不相信有真正足够的信息来提供太多的帮助:-(

首先,不要用NSZombie的坚持 - 我敢肯定,到时候你会得到它的发生。确保你检查了控制台输出,nszombie抛出的异常很可能会被捕获并被忽略。

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

,可能会或可能不会解决你的问题将是最后一个建议尝试ASIHTTPRequest来代替:

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

它可以做的一切NSURLConnection的可以做(和另外一个很多有用的东西),和如果您仍然崩溃,您至少可以获得源代码,以便获得有关错误的更多信息。

+1

+1为asihttprequest,因为它是这样的问题免费 – harshalb 2010-09-15 12:31:32

+0

啊是的很好的建议:)要马上检查它 – Vivi 2010-09-15 12:46:39

+0

只是与NSZombieEnabled错误...但回溯没有多大帮助: – Vivi 2010-09-15 12:55:50