保存异步下载的文件'内容到SQLITE

时间:2017-10-20 09:54:53

标签: ios objective-c cocoa-touch asynchronous

背景我正在遍历一堆网址以获取下载的多个文件。下载文件后,我需要解压缩'文件中的JSON并将数据插入到SQLite数据库中。

问题当下载文件时,我尝试将文件的内容插入到数据库中,因为文件是异步下载的,文件大小不同,第二个文件试图插入到第一个文件完成之前的数据库,因此数据库被锁定以备后续文件。

问题在尝试保存下一个文件之前,如何让文件等待上一个文件保存到数据库?

获取文件的代码:

-(void)downloadJsonDataFrom:(NSURL *)url withToken:(NSString*)token saveTo:(NSString *)saveLocation withName:(NSString*)fileName
{
    NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url];
    [request setHTTPMethod:@"GET"];
    [request addValue:@"application/json" forHTTPHeaderField:(@"content-type")];
    [request addValue:token forHTTPHeaderField:(@"X-TOKEN")]; 

    NSURLSessionConfiguration *sessionConfig = [NSURLSessionConfiguration defaultSessionConfiguration];
    NSURLSession *session = [NSURLSession sessionWithConfiguration:sessionConfig delegate:nil delegateQueue:nil];

    NSURLSessionDataTask *dataTask = [session dataTaskWithRequest:request completionHandler:^(NSData * data, NSURLResponse * response, NSError * error) {

    if (!error && data) {

        NSError *writeError = nil;
        BOOL writeOK = [data writeToFile:saveLocation options:NSDataWritingAtomic error:&writeError];

        if (writeOK) {
            NSLog(@"downloadTheFileFrom writeOK for %@", fileName);
           [sqlFileHandler saveJsonToSql:saveLocation];
        } else {
            NSLog(@"Error writing file : %@ %@", fileName, writeError);
        }


    } else {
        NSLog(@"downloadTheFileFrom Error : %@",error);
    }
}];
[dataTask resume];

1 个答案:

答案 0 :(得分:0)

使用GCD(Grand Central Dispatch)的串行队列。一些未经测试的代码:

dispatch_queue_t serialQueue = dispatch_queue_create("com.unique.sql.queue", DISPATCH_QUEUE_SERIAL);
dispatch_async(serialQueue, ^{
        [sqlFileHandler saveJsonToSql:saveLocation];
    }); 

对那些说服力的人来说有点儿了:

let serialQueue = DispatchQueue(label: "com.unique.sql.queue", attr: DISPATCH_QUEUE_SERIAL)
serialQueue.sync { 
    operationThatNeedsToRunSerially()
}