0

最初にここに私のクラッシュログがあります

Thread 1 name:  Dispatch queue: com.apple.root.default-priority
Thread 1 Crashed:
0   CoreFoundation                  0x3b8afc30 __CFBasicHashRehash + 796
1   CoreFoundation                  0x3b8b0e48 __CFBasicHashAddValue + 88
2   CoreFoundation                  0x3b7db194 CFBasicHashAddValue + 3048
3   CoreFoundation                  0x3b7deebc CFSetAddValue + 112
4   CoreData                        0x36ea45b0 -        [NSManagedObjectContext(_NSInternalAdditions) _insertObjectWithGlobalID:globalID:] + 172
5   CoreData                        0x36e9c9bc -[NSManagedObjectContext insertObject:] +     136
6   CoreData                        0x36e8c6d2 -[NSManagedObject     initWithEntity:insertIntoManagedObjectContext:] + 646
7   CoreData                        0x36e78d74 +[NSEntityDescription     insertNewObjectForEntityForName:inManagedObjectContext:] + 176
8   XYZ Orders                      0x000f8182 -[ITMLoginVC traverseElement:] (ITMLoginVC.m:1551)
9   XYZ Orders                      0x000f7eba -[ITMLoginVC traverseElement:] (ITMLoginVC.m:1506)
10  XYZ Orders                      0x000f5970 -[ITMLoginVC getAllCustomerValues]     (ITMLoginVC.m:903)
11  libdispatch.dylib               0x39b8911c _dispatch_call_block_and_release + 8
12  libdispatch.dylib               0x39b8d95c _dispatch_root_queue_drain + 248
13  libdispatch.dylib               0x39b8dabc _dispatch_worker_thread2 + 80
14  libsystem_c.dylib               0x368f2a0e _pthread_wqthread + 358
15  libsystem_c.dylib               0x368f28a0 start_wqthread + 4

行903:

if(ttbXML.rootXMLElement)
{
    [self traverseElement:ttbXML.rootXMLElement]; //line 903
}

1551行目:

ITMAllCustomerAddresses *allCustAddress =(ITMAllCustomerAddresses *)[NSEntityDescription                                                            insertNewObjectForEntityForName:@"ITMAllCustomerAddresses"
                                                                                                                        inManagedObjectContext:self.managedObjectContext];

1506行目:

         [self traverseElement:element->firstChild];

TBXMLを使用して解析しています。ここStackOverflowで、人々は大きなXMLの場合にTBXMLを使用することを提案しました。NSXMLParserを使用しましたが、速度が遅く、クラッシュしました。これもクラッシュしますが、高速で1日に1〜2回のようにクラッシュします。これもまれなケースです。今日これを手に入れたのはこれが2度目です。だから私はこれを投稿するかもしれないと思った。私のmanagedobjectcontextが適切に初期化されていないと思ったので、今は次のようにしています。

    if (!self.managedObjectContext)
{
    self.managedObjectContext  = self.appDelegate.managedObjectContext;
}

なぜこのように動作するのかについて誰かが何か考えを持っているなら、私に教えてください。さらに詳しい情報が必要な場合は、お知らせください。ありがとう。iOS6で、iPhoneデバイスのテストを行っています。その社内アプリ。シミュレータで正常に動作します。

4

0 に答える 0