使用GCD

时间:2015-05-26 18:34:06

标签: ios objective-c grand-central-dispatch

我正在尝试从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并不熟悉,所以我确信它与此有关。

如果有人有任何建议,我将不胜感激。

谢谢!

1 个答案:

答案 0 :(得分:2)

尝试将dispatch_async中的此[graph strokeChart];包装回主队列。

否则我会建议使用乐器分析应用程序。

使用Time Profiler检查执行时间并查看花费的时间。

然后,您可以检查线程视图以查看工作的完成位置以及发生等待的位置。

虽然看起来你不需要这个工作的派遣小组。