背景我正在遍历一堆网址以获取下载的多个文件。下载文件后,我需要解压缩'文件中的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];
答案 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()
}