我正在尝试从HealthKit中提取数据,正确地提取数据并且速度足够快。我认为我的GCD设置方式可能有问题。
以下是代码:
- (void)loadGraphDataForType:(NSString *)type withDuration:(int)graphDuration {
NSCalendar *calendar = [NSCalendar currentCalendar];
NSDateComponents *interval = [NSDateComponents new];
if (graphDuration == 1) {
interval.hour = 1;
} else {
interval.day = 1;
}
NSMutableArray *arrayOfValues = [NSMutableArray new];
NSDate *anchorDate = [calendar startOfDayForDate:[NSDate date]];
HKQuantityType *quantityType = [HKQuantityType quantityTypeForIdentifier:type];
dispatch_queue_t queue = dispatch_queue_create([@"graph.queue" UTF8String], DISPATCH_QUEUE_CONCURRENT);
dispatch_group_t group = dispatch_group_create();
dispatch_group_async(group, queue, ^{
dispatch_semaphore_t lock = dispatch_semaphore_create(0);
HKStatisticsCollectionQuery *query = [[HKStatisticsCollectionQuery alloc] initWithQuantityType:quantityType quantitySamplePredicate:nil options:HKStatisticsOptionCumulativeSum anchorDate:anchorDate intervalComponents:interval];
query.initialResultsHandler = ^(HKStatisticsCollectionQuery *query, HKStatisticsCollection *results, NSError *error) {
if (error) {
NSLog(@"Error: %@ %@", error, [error userInfo]);
} else {
NSDate *endDate = [NSDate date];
NSDate *startDate = [calendar dateByAddingUnit:NSCalendarUnitDay value:-graphDuration toDate:endDate options:0];
[results enumerateStatisticsFromDate:startDate toDate:endDate withBlock:^(HKStatistics *result, BOOL *stop) {
HKQuantity *quantity = result.sumQuantity;
if (quantity != nil) {
double value = 0;
//Steps Traveled
value = [quantity doubleValueForUnit:[HKUnit countUnit]];
int intValue = (int)value;
[arrayOfValues addObject:@(intValue)];
} else {
[arrayOfValues addObject:@0];
}
}];
dispatch_semaphore_signal(lock);
}
};
[self.healthStore executeQuery:query];
dispatch_semaphore_wait(lock, DISPATCH_TIME_FOREVER);
});
dispatch_group_notify(group, queue, ^{
graphData = [PNLineChartData new];
graphData.color = [UIColor whiteColor];
graphData.itemCount = [arrayOfValues count];
graphData.getData = ^(NSUInteger index) {
CGFloat yValue = [arrayOfValues[index] floatValue];
return [PNLineChartDataItem dataItemWithY:yValue];
};
graph.chartData = @[graphData];
[graph strokeChart];
});
}
如果我给图表得到项目计数的断点,它显示25(这是正确的),我可以看到数组内部的数据,但图表显示前5分钟。我现在尝试了几个不同的库,它们的行为都相同,所以我认为这是我的代码中导致它的原因。
我对GCD并不熟悉,所以我确信它与此有关。
如果有人有任何建议,我将不胜感激。
谢谢!
答案 0 :(得分:2)
尝试将dispatch_async中的此[graph strokeChart];
包装回主队列。
否则我会建议使用乐器分析应用程序。
使用Time Profiler检查执行时间并查看花费的时间。
然后,您可以检查线程视图以查看工作的完成位置以及发生等待的位置。
虽然看起来你不需要这个工作的派遣小组。