有关于串行任务和dispatch_queue的问题 我的样本是: 有1101个项目插入到sqlite中,我使用'insert into select union all select'来做插入作业,但是sqlite只支持500个项目,所以单独的数据并逐个插入, 问题是我的数据库操作模型在一个dispatch_queue(一个串行队列)中处理所有sql,并在完成一个任务时使用一个块来做回调。
所以如果我想在task1成功完成后做task2,我就不能,因为调度队列 关于这个设计的任何想法或建议,或者如果保留调度队列,我该怎么办?
当前代码:
for(int i = 0; i<n;i++) //n tasks
{
do a task in dispatch queue:^(BOOL success){
if(success)
do task 2
}
}
非常感谢
答案 0 :(得分:0)
考虑到队列是串行的,这样的事情怎么样:
__block NSError* _task_error = nil;
for(int i = 0; i<n;i++) //n tasks
{
dispatch_async(queue, ^ {
if(_task_error != nil) return; //There was an error in a previous task - we done.
//Try performing operation, and on error - set _task_error to hold information on the problem.
}
}
//Finally, add cleanup operation to log final result.
dispatch_async(queue, ^ {
//Write to your log here, notify handlers on error, etc.
//Finally, clean the _task_error so next batch has a clean start.
_task_error = nil;
}
由于队列是串行的并且FIFO是有保证的,因此块将按顺序执行,如果先前的任务不成功,则不会尝试任务。