- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我有一个 NSManagedObjectContext 声明如下:
- (NSManagedObjectContext *) backgroundMOC {
if (backgroundMOC != nil) {
return backgroundMOC;
}
backgroundMOC = [[NSManagedObjectContext alloc] initWithConcurrencyType:NSPrivateQueueConcurrencyType];
return backgroundMOC;
}
-(void)testThreading
{
/* ok */
[self.backgroundMOC performBlock:^{
assert(![NSThread isMainThread]);
}];
/* CRASH */
[self.backgroundMOC performBlockAndWait:^{
assert(![NSThread isMainThread]);
}];
}
performBlockAndWait
在主线程而不是后台线程上执行任务?
最佳答案
折腾另一个答案,尝试解释原因 performBlockAndWait
将始终在调用线程中运行。performBlock
是完全异步的。它总是将块入队到接收 MOC 的队列中,然后立即返回。因此,
[moc performBlock:^{
// Foo
}];
[moc performBlock:^{
// Bar
}];
processPendingChanges
)。
performBlockAndWait
不使用内部队列。它是在调用线程的上下文中执行的同步操作。当然,它会等到队列上的当前操作执行完毕,然后该块将在调用线程中执行。这是有记录的(并在几个 WWDC 演示文稿中重申)。
performBockAndWait
是可重入的,因此嵌套调用都发生在该调用线程中。
performBlock*
的同步API 是关键。
performBlockAndWait
是“这个块将在某个不确定的时间执行,在这个完全相同的线程中。该函数将在此代码完全执行后返回(这将在与此 MOC 关联的当前队列耗尽后发生)。”
Are you sure of "performBlockAndWait does NOT use the internal queue"? I think it does. The only difference is that performBlockAndWait will wait until the block's completion. And what do you mean by calling thread? In my understanding, [moc performBlockAndWait] and [moc performBloc] both run on its private queue (background or main). The important concept here is moc owns the queue, not the other way around. Please correct me if I am wrong. – Philip007
performBlockAndWait
时在私有(private)队列上,块将在调用该函数的线程上执行 - 它不会被放入队列并在“私有(private)线程”上执行。
performBlockAndWait
不建议不要在主线程上执行,因为它将在调用它的线程上执行。
performBlockAndWait
使用 GCD,但它也有自己的层(例如,防止死锁)。如果您查看 GCD 代码(它是开源的),您可以看到同步调用是如何工作的 - 通常它们与队列同步并调用调用该函数的线程上的块 - 除非队列是主队列或全局队列。此外,在 WWDC 会谈中,Core Data 工程师强调了
performBlockAndWait
的观点。将在调用线程中运行。
performBlockAndWait
时它不会将块放在队列中……而是同步访问并在调用该函数的线程上运行提交的块。
performBlock*
时或者 GCD 函数,你不应该期望它在任何特定线程上运行(除了与主线程相关的东西),因为队列不是线程,只有主队列会在特定线程上运行块。
performBlockAndWait
该块将在调用线程中执行(但将与提交到队列的所有内容适当同步)。
performBlockAndWait
的方式。提供可重入支持打破块的 FIFO 排序。举个例子...
[context performBlockAndWait:^{
NSLog(@"One");
[context performBlock:^{
NSLog(@"Two");
}];
[context performBlockAndWait:^{
NSLog(@"Three");
}];
}];
performBlockAndWait
(“三”)将在异步块(“二”)之后运行,因为它是在异步块提交之后提交的。然而,情况并非如此,因为这是不可能的......出于同样的原因,嵌套
dispatch_sync
会导致死锁。调用。如果使用同步版本,则需要注意一些事项。
dispatch_sync
可能导致死锁,以及任何可重入版本,例如
performBlockAndWait
将不得不做出一些“错误”的决定来支持它......就像让同步版本“跳”队列一样。
关于iphone - NSManagedObjectContext performBlockAndWait : doesn't execute on background thread?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11831946/
我是 os 2 的新手,所以真的不知道从哪里开始。是否可以编写一个 WatchOs 2 应用程序,它将在后台运行并每小时唤醒一次?网上没有那么多可用的信息,但到目前为止我所看到的表明不可能编写后台应用
如何将 url 背景图像添加到渐变中并具体定位?因为梯度本身被当作图像 CSS background: linear-gradient(to bottom, #98cb01 2%,#60a822 10
我是 android 开发的新手,正在开发我的第一个 android 应用程序。我在布局的 xml 中设置了 View 的背景颜色,如下所示。 android:background="@+color/
为了尽可能简洁地使用样式,如果使用双像素密度设备(例如 iPhone 4)查看我的页面,我宁愿不使用包含的媒体查询样式表。 话虽如此,如果我只是做这样的事情就可以了吗? .icon-1 { bac
我有一个由 62 张 91 * 91 像素的图像组成的 Sprite ,这使得整个图像为 91 * 5642 像素。它们以动态网格的形式显示,该网格会根据用户/指针的移动而增长和缩小。有时,一个元素(
我一直在尝试制作一款使用 Xbox One Kinect (V2) 的 Unity 游戏。 我遵循了本教程中的说明: http://www.imaginativeuniversal.com/blog/
看来firefox会自动组合一些东西,例如它需要单独的css值,例如“border-color”,“border-width”并将它们全部转储到“border”中..这使jquery变得很痛苦因为 .
我正在构建我的第一个 Chrome 扩展程序。我浏览了 Chrome 开发人员文档,但我无法理解几个主题。 我的理解: 有两个 Action : 浏览器操作(地址栏外的按钮) 页面操作(地址栏内的按钮
我的后台监听器是 chrome.runtime.onMessage.addListener(function (request, sender, sendResponse) 在chrome.conte
哪个更有效: 我正在尝试找出哪种提供半透明背景的方法更有效/更快: background-color: rgba(255, 255, 255, .12); 或者 background-image: u
我想要一个有 tr 作为黑色背景的表格,里面有一个白色背景的表格。
我在我的主页上放了一个背景。它可以在除 android chrome 之外的所有浏览器上正确显示。这是我的 CSS: body.path-frontpage { background-imag
我正在尝试对我的背景图像应用滤镜,但是我遇到了 CSS 属性 URL 和线性渐变的问题。我想要的背景图片 .bg-image-full { background: no-repeat center
在样式部分的 chrome 中使用谷歌开发者控制台时,它会立即为我提供“在我键入时”的背景颜色属性。几个月前,它一直在提供我更喜欢的一般属性(property)“背景”。 是否有机会自定义这些提示,或
我正在尝试实现 faux column网站上的布局。简而言之,它涉及在包含两个垂直列的 div 上平铺背景图像,使其看起来像两个列一直延伸到底部。 我的专栏如下所示: XXXX MMMM XXXX
这是一个 example .我想裁剪背景图像,然后将裁剪图像用作更大(尺寸)元素的背景。我的意思是 div 比它的背景大,我不需要重复。现在,当 background-repeat 取消注释时,元素消
CSS3 声明 background-clip 和 background-origin 似乎对背景有相同的效果。它们似乎都将背景限制在相对于 HTML 元素的某个区域,所以我想知道这两个声明在功能上是
我正在为图片库制作缩略图页面。缩略图预览作为 完成 float 具有固定的方形尺寸。 然而,缩略图本身不一定是正方形或相同大小,它们具有它们所代表的大图像的属性。 为了让它看起来不错,我想在正方形中
这个问题在这里已经有了答案: Get a CSS value with JavaScript (8 个答案) 关闭 6 年前。
你好, 就像我在标题中所说的 background-image:none; 不起作用,因为使用 css3 background-image:url('...'); 返回一个新层每次文件都是新的。我正在
我是一名优秀的程序员,十分优秀!