基本问题,我确信有一个简单的答案。
我正在尝试获取照片的时间戳。当我尝试访问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中的第一次探索之一。
答案 0 :(得分:7)
您正在使用%@
作为整数的格式说明符。您需要使用%d
。
当您使用%@
时,NSLog
函数会将参数视为对象,并向其发送description
消息。真正发生的是,运行时尝试取消引用参数(整数)但由于它不是有效指针,因此会出现EXC_BAD_ACCESS
异常。