NSDateComponents - EXC_BAD_ACCESS错误

时间:2010-02-09 02:03:26

标签: objective-c cocoa

基本问题,我确信有一个简单的答案。

我正在尝试获取照片的时间戳。当我尝试访问NSDateComponents以检索特定的日期元素(例如“天”)时,我收到一个EXC_BAD_ACCESS错误。

首先,我的代码的相关位:

// formattedDateString is a string representing the "DateTimeOriginal" EXIF property extracted from the image   
NSDate *takenAt = [[NSDate alloc] initWithString:formattedDateString];
NSLog(@"date: %@", takenAt); // prints= date: 2010-01-10 03:25:00 -0500

NSCalendar *gregorian = [[NSCalendar alloc] initWithCalendarIdentifier:NSGregorianCalendar];
NSLog(@"cal: %@", gregorian); // prints= cal: <__NSCFCalendar: 0x10020b570>

NSUInteger unitFlags =  (NSYearCalendarUnit | NSMonthCalendarUnit | NSDayCalendarUnit | NSHourCalendarUnit | NSMinuteCalendarUnit | NSSecondCalendarUnit);      
NSDateComponents *components = [gregorian components: unitFlags 
                                            fromDate: takenAt
                               ];

int days = [components hour];
NSLog(@"comp: %@", days); // thrown error= Program received signal:  “EXC_BAD_ACCESS”

如果我注释掉最后一行: NSLog(@“comp:%@”,days); 代码执行成功。

我在这方面尝试了一些变体,但最重要的是,每当我向组件发送消息以访问属性时,都会引发“EXC_BAD_ACCESS”错误。

我所做的研究似乎表明,这通常是未初始化的指针或我尝试发布的对象的结果,而不是我要发布的。据我所知,情况并非如此。

我错过了什么?

提前感谢您为我揭开这一点。这是我在Objective-C中的第一次探索之一。

NSDateComponents class reference

1 个答案:

答案 0 :(得分:7)

您正在使用%@作为整数的格式说明符。您需要使用%d

当您使用%@时,NSLog函数会将参数视为对象,并向其发送description消息。真正发生的是,运行时尝试取消引用参数(整数)但由于它不是有效指针,因此会出现EXC_BAD_ACCESS异常。