从并发线程同时在主DispatchQueue上调度块是否安全



在我的代码中,我使用for循环将并发任务调度到全局调度队列,如下所示:

for collectionMember in myCollection {
DispatchQueue.global(qos: .default).async {
// do stuff here with collectionMember and store in variable "result"
DispatchQueue.main.async {
// code using variable "result" that must be executed serially on main thread
// because accesses shared resources
}
}

我是Grand Central Dispatch的新手,我担心当不同的并发线程试图在主DispatchQueue上调度块时,会出现一些内存问题,因为它们都访问主DispatchQueue。

我希望并发线程在完成时向主DispatchQueue添加一个块,而不会出现线程安全问题。

我是否必须在将代码调度到主DispatchQueue的块周围使用锁,或者调度块线程是安全的?

最后,如果我有任何错误,或者有更简单的方法来解决这个问题,请告诉我。谢谢

不需要锁。主队列是一个锁!这就是重点(好吧,很多重点(。它是一个串行队列;只要其他东西已经在执行,就不能在主队列上开始执行任何东西。主线程中没有并发。你所做的是完全正确的;请注意,您可能正在排列一整堆要在主线程上执行的块,一次一个。但这不是问题,除非这里有很多。

相关内容

  • 没有找到相关文章

最新更新