- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
在过去的一个问题中,我询问了关于在没有破坏竞争的情况下实现 pthread barrier 的问题:
How can barriers be destroyable as soon as pthread_barrier_wait returns?
并从 Michael Burr 那里收到了针对进程本地障碍的完美解决方案,但对于进程共享障碍却失败了。我们后来也有过一些想法,但一直没有得出令人满意的结论,甚至没有开始进入资源故障案例。
是否有可能在 Linux 上制作满足这些条件的屏障:
Michael 尝试解决进程共享的情况(参见链接的问题)有一个不幸的特性,即必须在等待时分配某种系统资源,这意味着等待可能会失败。并且不清楚当屏障等待失败时调用者可以合理地做什么,因为屏障的全部要点是在剩余的 N-1
线程到达它之前继续进行是不安全的...
内核空间解决方案可能是唯一的方法,但即使这样也很困难,因为信号可能会中断等待而没有可靠的方法来恢复它...
最佳答案
这对于 Linux futex API 是不可能的,我认为这也可以被证明。
我们这里基本上有一个场景,其中 N 个进程必须被一个最终进程可靠地唤醒,并且在最终唤醒之后任何进程都不能触及任何共享内存(因为它可能被异步销毁或重用)。虽然我们可以很容易地唤醒所有进程,但基本的竞争条件是在唤醒和等待之间;如果我们在等待之前发出唤醒,掉队者永远不会醒来。
通常解决此类问题的方法是让掉队者在等待时自动检查状态变量;如果唤醒已经发生,这允许它完全避免 sleep 。然而,我们不能在这里这样做——一旦唤醒成为可能,接触共享内存是不安全的!
另一种方法是实际检查是否所有进程都已进入休眠状态。但是,这对于 Linux futex API 是不可能的;等待者数量的唯一指示是 FUTEX_WAKE 的返回值;如果它返回的服务员人数少于您预期的人数,您就知道有些人还没有睡着。然而,即使我们发现我们没有唤醒足够多的服务员,现在做任何事情都为时已晚 - 确实唤醒的进程之一可能已经破坏了屏障!
因此,不幸的是,这种可立即销毁的原语无法使用 Linux futex API 构建。
请注意,在一个服务员,一个叫醒者的特定情况下,可能可以解决该问题;如果 FUTEX_WAKE 返回零,我们知道实际上还没有人被唤醒,所以你有机会恢复。然而,将其变成一个高效的算法非常棘手。
向 futex 模型添加一个强大的扩展来解决这个问题是很棘手的。基本问题是,我们需要知道 N 个线程何时成功进入等待状态,并以原子方式将它们全部唤醒。但是,这些线程中的任何一个都可能随时等待运行信号处理程序 - 实际上,waker 线程也可能等待信号处理程序。
然而,一种可行的方法是对 keyed event 的扩展NT API 中的模型。对于键控事件,线程成对地从锁中释放;如果您有一个没有“等待”的“释放”,则“释放”调用会阻止“等待”。
由于信号处理程序的问题,这本身是不够的;但是,如果我们允许“release”调用指定多个线程以原子方式唤醒,这就可行了。您只需让屏障中的每个线程递减一个计数,然后“等待”该地址上的键控事件。最后一个线程“释放”了 N - 1 个线程。在所有 N-1 个线程都进入此键控事件状态之前,内核不允许处理任何唤醒事件;如果任何线程由于信号(包括释放线程)而离开 futex 调用,这将完全阻止任何唤醒,直到所有线程都返回。
关于能否在 Linux 上实现正确的故障安全进程共享屏障?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6935769/
有人可以解释一下为什么这个脚本不起作用吗? function destroy(ID) { if (confirm("Deleting is a very bad thing! Sure?")
我正在尝试使 WCF Silverlight 故障按此方式工作: MSDN aricle 将 SL 故障添加到我的 Web.config 文件后,我收到以下警告: The element 'behav
这是我要删除的 Haskell 函数 2::Int和 5::Int从列表中: remPrimesFactors25 :: [Int] -> [Int] remPrimesFactors25 [] =
当我想用 ffmpeg 连接和录制两个 mp4 视频时,我遇到了这个问题。我得到的输出是: [concat @ 0x2566e80] DTS 4079 #0:0 (h264 (native) ->
我想在delphi中编写一个程序来模拟以特定速度移动的鼠标指针(类似于AutoIT MouseMove函数)。要么是我的代码错误,要么是 SetCursorPos 在被调用太多次后出现故障。这是我的功
我将“wa、or 和 id”(来自这些州的访问者)设置为重定向到 website1.com - 当我访问该网站时,它会将我重定向到 website1.com(因此它知道我在 WA) 。但如果我将 wa
我们目前正在争论通过 WCF channel 抛出错误与传递指示状态或服务响应的消息是否更好。 故障带有 WCF 的内置支持,您可以使用内置的错误处理程序并做出相应的 react 。然而,这会带来开销
不确定我在这里做错了什么,如果有任何帮助,我们将不胜感激。 尝试创建一个名为“control”的新变量,并在行变量等于这些数字时将其编码为 1,否则编码为 0。 data$control= ifels
我想在应用洞察中记录成功调用的百分比。我看到这篇文章https://learn.microsoft.com/en-us/azure/azure-monitor/app/sampling我认为固定速率采
我正在尝试使用 SVD 和特征分解来使用动态模式分解进行一些数据分析。我遇到了一个简单的问题,即从 Matlab 和 Python 获得不同的结果。我很困惑,不知道为什么 Python 给我错误的结果
This question already has an answer here: mysqli_fetch_assoc() expects parameter / Call to a member
我刚刚开始我的一个实验室,在那里我计算类(class)的 GPA,其信息存储在结构的链接列表中。截至目前,我正在尝试打印所有类(class)信息,以确保它们已正确初始化并添加到链接列表中。 我遇到了一
我正在尝试学习如何使用 visual studio 为 C++ 制作 GUI。但是我在使用 GetWindowText() 函数时遇到了一些问题。它不会将 LPTSTR 标题更改为文本框中的文本,并且
我有一个奇怪的问题。它似乎只出现在测试者的 iPhone 5s 上。它可以在运行最新 iOS (8.3) 的 iPhone 5、6 和 6 plus 上正常运行。 这是代码 -(NSString *)
我正在尝试更新 Core Data 中的一些记录。我正在采取以下步骤来完成它 带谓词的获取函数从核心数据中检索记录 将结果集存储在对象数组中 遍历数组并更新每条记录 调用保存上下文 我遇到了两个问题
我通过 Storyboard设计了 tableView,在一个单元格中我有一个按钮和一个标签。按钮在 Storyboard上有标签 1 和标签在 Storyboard上有标签 2。在 cellForR
我实现了这个方法,当在文本字段中输入了未经授权的字符或已使用的用户名时,向用户发送多个警报 View : func textFieldShouldEndEditing(textField: UITex
伙计们,我在运行程序时遇到了这个非常奇怪的错误。这是重要的代码: 变量(编辑): const short int maxX = 100; const short int maxZ = 100; con
我有这个修改过的 Matrix Javascript 代码,我想摆脱第一次运行的所有与自身重叠的字符串。有人知道我该如何管理吗?另外,我想在我的网页上多次使用此代码,我需要声明新变量,不是吗?但是当我
有谁知道是否有网站(甚至非 Microsoft)有关于 COMExceptions/HRESULTS 的详细信息。 当我尝试在使用 Copy() 函数后保存我的 Excel 工作簿时,我收到此错误:
我是一名优秀的程序员,十分优秀!