2012-07-21 84 views
1

我在IOS 5.1模拟器运行下面的代码时:EXC_BAD_ACCESS设定核心数据对象的标量属性(IOS 5)

Table* sparkFront = 
    [NSEntityDescription insertNewObjectForEntityForName:@"Table" 
           inManagedObjectContext:_context]; 
NSLog(@"%@", sparkFront); 
NSEntityDescription* entity = [NSEntityDescription entityForName:@"Table" 
              inManagedObjectContext:_context]; 
NSDictionary* dict = [entity propertiesByName]; 
for (NSObject* key in [dict allKeys]) 
{ 
    NSLog(@"%@", key); 
} 
sparkFront.columnValuesAddress = 0x606; 

此代码与EXC_BAD_ACCESS崩溃上的最后一行。表对象是一个核心数据对象实现如下:

@interface Table : NSManagedObject 
@property (nonatomic) int32_t columnValuesAddress; 
@end 

我知道核心数据本身并不做标量类型,但是这是一个IOS 5+唯一的应用程序,而我的印象是联合国下属/拳击自动完成。在飞机坠毁前,上面的代码的输出显示我的背景和实体都不错:

2012-07-20 22:17:52.714 otest[95147:7b03] <NSManagedObject: 0x9c87b20> (entity: Table; id: 0x9c86a80 <x-coredata:///Table/t2C0D90D5-E381-4BD0-B65D-8FC83C6D50DB2> ; data: { 
columnValuesAddress = 0; 
}) 
2012-07-20 22:17:52.716 otest[95147:7b03] columnValuesAddress 

空难后,问题报告显示以下内容:

Application Specific Information: 
objc_msgSend() selector name: isNSNumber__ 
Simulator libSystem was initialized out of order. 


Thread 0 Crashed: 
0 libobjc.A.dylib     0x00635098 objc_msgSend + 12 
1 CoreData      0x05c2e833 _PFManagedObject_coerceValueForKeyWithDescription + 483 
2 CoreData      0x05bfe3d1 _sharedIMPL_setvfk_core + 209 
3 CoreData      0x05c16687 _svfk_0 + 39 
4 ECMCalTests      0x0187f8f1 -[ECMCalTests testInsertRecords] + 849 (ECMCalTests.m:73) 
5 CoreFoundation     0x003f74ed __invoking___ + 29 
6 CoreFoundation     0x003f7407 -[NSInvocation invoke] + 167 
7 SenTestingKit     0x201039c4 -[SenTestCase invokeTest] + 184 
8 SenTestingKit     0x20103868 -[SenTestCase performTest:] + 183 
9 SenTestingKit     0x201034a9 -[SenTest run] + 82 
10 SenTestingKit     0x20106db2 -[SenTestSuite performTest:] + 106 
11 SenTestingKit     0x201034a9 -[SenTest run] + 82 
12 SenTestingKit     0x20106db2 -[SenTestSuite performTest:] + 106 
13 SenTestingKit     0x201034a9 -[SenTest run] + 82 
14 SenTestingKit     0x20105e97 +[SenTestProbe runTests:] + 174 
15 CoreFoundation     0x00492d51 +[NSObject performSelector:withObject:] + 65 
16 otest       0x0000231c 0x1000 + 4892 
17 otest       0x000025be 0x1000 + 5566 
18 otest       0x00002203 0x1000 + 4611 
19 otest       0x00001f8d 0x1000 + 3981 
20 otest       0x00001f31 0x1000 + 3889 

我在做什么错?

更新:我根据核心数据教程实现了属性的setter/getter。它仍然崩溃。它从来没有在setter中达到一个断点,所以在它调用setter之前它就会崩溃。我在Apple的代码中遇到错误吗?

@interface Table : NSManagedObject 
{ 
    int32_t columnValuesAddress; 
} 
@property (nonatomic) int32_t columnValuesAddress; 
@end 

@implementation Table 

- (int32_t)columnValuesAddress 
{ 
    [self willAccessValueForKey:@"columnValuesAddress"]; 
    int32_t address = columnValuesAddress; 
    [self didAccessValueForKey:@"columnValuesAddress"]; 
    return address; 
} 

- (void)setColumnValuesAddress:(int32_t)address 
{ 
    [self willChangeValueForKey:@"columnValuesAddress"]; 
    columnValuesAddress = address; 
    [self didChangeValueForKey:@"columnValuesAddress"]; 
} 

- (void)setNilValueForKey:(NSString *)key 
{ 
    if ([key isEqualToString:@"columnValuesAddress"]) 
    { 
    self.columnValuesAddress = 0; 
    } 
    else 
    { 
    [super setNilValueForKey:key]; 
    } 
} 

@end 
+1

尝试做拳击和拆箱自己,看看它是否仍然崩溃 – borrrden 2012-07-21 05:55:20

+0

它说iOS 5自动(联合国)拳击? – 2012-07-21 06:13:22

+0

它的确为你准备的和吸气剂是我的意思。 – ToBeFrank 2012-07-21 16:01:28

回答

0

我创建了一个全新的项目,从零开始重新创建模型,并将其复制到旧项目的测试代码中。这个新项目工作正常。我不知道为什么旧项目不起作用,但至少有一个解决方案。

+0

这是Xcode中的一个错误。我可以确认它在4.4中被修复。 – ToBeFrank 2012-07-28 23:26:47

0

在实体编辑器中,您需要设置您的类。它是在您使用文件模板创建核心数据类文件时为您设置的。我创建了一个没有模板的类文件,因此该类没有设置,所以我得到了这些错误。如果它能够看到课程并且看到您将其指定为assign,它只会自动打开并取消打开。