- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
在选择要在哪个队列上运行 dispatch_async
时,经常会提到 dispatch_get_global_queue
。这是一个将任务委托(delegate)给特定线程的特殊后台队列吗?是不是差不多是单例了?
因此,如果我总是为我的 dispatch_async
调用使用该队列,该队列是否会变满并且必须等待事情完成才能开始另一个任务,或者它是否可以将其他任务分配给不同的线程?
我想我有点困惑,因为当我为 NSOperation
选择队列时,我可以使用 [NSOperationQueue mainQueue]
选择主线程的队列>,这似乎是 dispatch_get_main_queue
的同义词,但我的印象是 NSOperation
的后台队列必须是 NSOperationQueue
的单独实例,但 GCD 有后台队列的单例? (dispatch_get_global_queue
)
此外 - 愚蠢的问题但想确定 - 如果我将任务放入队列中,队列将分配给 一个 线程,对吗?如果任务足够大,它不会将其拆分为多个线程,对吗?
最佳答案
When selecting which queue to run dispatch_async on, dispatch_get_global_queue is mentioned a lot. Is this one special background queue that delegates tasks to a certain thread?
某个线程?不会。dispatch_get_global_queue
会为您检索具有所请求相对优先级的全局队列。 dispatch_get_global_queue
返回的所有队列都是并发的,并且可以根据系统的判断将工作分派(dispatch)给许多不同的线程。这种机制是一个实现细节,对于作为 API 使用者的您来说是不透明的。
在实践中,并且冒着过于简单化的风险,每个优先级都有一个全局队列,在撰写本文时,根据我的经验,每个优先级都将在任何给定时间将工作分派(dispatch)到0 和 64 线程。
Is it almost a singleton?
绝对不是,但您可以将它们视为单例,其中每个优先级都有一个单例。
So if I use that queue always for my dispatch_async calls, will that queue get full and have to wait for things to finish before another one can start, or can it assign other tasks to different threads?
它可以装满。实际上,如果您正在使一个全局并发队列饱和(即超过 64 个相同优先级的后台任务同时运行),您的设计可能很糟糕。 (有关队列宽度限制的更多详细信息,请参阅 this answer)
I guess I'm a little confused because when I'm choosing the queue for an NSOperation, I can choose the queue for the main thread with [NSOperationQueue mainQueue], which seems synonymous to dispatch_get_main_queue
它们不是严格意义上的同义词。虽然 NSOperationQueue
在底层使用 GCD,但还是有一些重要的区别。例如,在主运行循环的单次传递中,只有一个排队到 +[NSOperationQueue mainQueue]
的操作将被执行,而提交到 dispatch_get_main_queue
的多个 block 可能在单个运行循环过程中执行。这对您来说可能无关紧要,但严格来说,它们不是一回事。
but I was under the impression background queues for NSOperation had to be individually made instances of NSOperationQueue, yet GCD has a singleton for a background queue? (dispatch_get_global_queue)
简而言之,是的。听起来您将 GCD 和 NSOperationQueue
混为一谈。 NSOperationQueue
不仅仅是 GCD 的“简单包装器”,它是它自己的东西。它是在 GCD 之上实现的,这对您来说并不重要。 NSOperationQueue
是一个任务队列,具有明确可设置的宽度,您可以“随意”创建实例。你可以随心所欲地制作它们。在某些时候,NSOperationQueue
的所有实例在执行 NSOperations
时,都从与进程的其余部分(包括 GCD)相同的系统资源池中提取资源,所以是的,那里有一些交互,但它们对您来说是不透明的。
Furthermore - silly question but wanted to make sure - if I put a task in a queue, the queue is assigned to one thread, right? If the task is big enough it won't split it up over multiple threads, will it?
单个任务只能在单个线程上执行。没有什么神奇的方法可以让系统将单一任务“拆分”为子任务。那是你的工作。关于您的具体措辞,队列 不是“分配给一个线程”,任务 是。队列中要执行的下一个任务可能会在完全不同的线程上执行。
关于ios - 如果我想让任务在后台运行, "dispatch_get_global_queue"队列如何工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21122334/
以下代码: dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_HIGH, 0), ^{ for (int i=0
我有这行代码: let queue = dispatch_get_global_queue(DISPATCH_QUEUE_CONCURRENT, 0); 我收到错误 Cannot invoke dis
我有这个简单的异步代码。 class MyClass { func myFunc() { dispatch_async(dispatch_get_global_queue(DI
在选择要在哪个队列上运行 dispatch_async 时,经常会提到 dispatch_get_global_queue。这是一个将任务委托(delegate)给特定线程的特殊后台队列吗?是不是差不
我继承了一个使用以下线程结构的代码库: dispatch_async(dispatch_get_main_queue(), { () -> Void in dispatch_async(dis
这个问题在这里已经有了答案: How do I dispatch_sync, dispatch_async, dispatch_after, etc in Swift 3, Swift 4, and
我刚刚开始在 iOS 上工作,并且一直在浏览 GCD 上的 Apple 引用资料。 dispatch_get_global _queue 返回一个并发队列,可以向其中提交要执行的 block 。 但是
我正在编写一个中等复杂的 iOS 程序,它需要有多个线程来执行一些较长的操作(解析、连接到网络等)。但是,我对 dispatch_get_global_queue 和 dispatch_queue_c
开始学习核心数据和 dispatch_async。有一段代码可以从一组数据中获取图像的 url 并将其设置为核心数据的模型,如下所示 dispatch_async(dispatch_get_globa
苹果的文档说,dispatch_get_global_queue()是并发队列,dispatch_sync是串行的意思,那么任务是异步处理还是同步处理? 最佳答案 您对什么是队列以及异步与同步的含义感
虽然使用 GCD 为后台线程创建的普通队列需要 dispatch_release 来释放对象的内存,但获取全局队列是否也需要做同样的事情,因为释放全局队列可能会导致操作系统出现问题我问:持有对由 di
我有一个表格 View ,其中我显示了 3 个单元格,并且取决于像分页一样工作的 Collection View 单元格。所以当我想从 dispatch_async(dispatch_get_glob
我有以下使用 block 获取联系人的代码片段: if (&ABAddressBookCreateWithOptions != NULL) { CFErrorRef error
let downloadGroup = dispatch_group_create() var images = [UIImage]() var errors = [NSError](
// Method called when a button is clicked - (void)handleClickEvent { dispatch_sync(dispatch_ge
我是一名优秀的程序员,十分优秀!