- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在过去的几个月里,我读了一些关于并行编程的书,我决定通过学习 posix 线程来结束它。
我正在阅读“PThreads 编程 - 更好的多处理简明手册的 Posix 标准”。在第 5 章(Pthreads 和 Unix)中,作者讨论了在多线程程序中处理信号。在“Threadsafe Library Functions and System Calls”一节中,作者做了一个我在读过的大多数关于并行编程的书中都没有看到的声明。声明是:
Race conditions can also occur in traditional, single-threaded programs that use signal handlers or that call routines recursively. A single-threaded program of this kind may have the same routine in progress in various call frames on its process stack.
我觉得解读这个陈述有点乏味。当递归函数使用静态存储类型保持内部结构时,是否会出现递归函数中的竞争条件?
我也很想知道信号处理程序如何导致单线程程序中的竞争条件
注意:我不是计算机科学专业的学生,我非常感谢简化的术语
最佳答案
我认为不能将其称为经典意义上的竞争条件。竞争条件具有某种随机行为,具体取决于调度程序策略和时间安排。
作者可能在谈论从多个递归调用访问同一对象/资源时可能出现的错误。但这种行为是完全确定的和可管理的。
另一方面,信号是一个不同的故事,因为它们是异步发生的,并且显然可以在中间中断一些数据处理并触发对该数据的一些其他处理,当返回到被中断的任务时破坏它。
关于c - 竞争条件也可能发生在传统的单线程程序中 - Clarity,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50497666/
此代码似乎在启用优化的广泛使用的编译器上中断,尽管它在 Visual Studio 中运行良好。 struct foo { foo(int a) { s[0] = '0'+a%10;s[1]
我想要一个图表,其中有一个单线箭头,如下所示: 1 2 3 4 5 或者像这样(其中/假设是一个箭头:)): \/ -----------------
我正在为 Java 编写自定义规则。有两个 Tree.KIND 实例(STRING_LITERAL 和 ASSIGNMENT)需要捕获。有一个特定的行,字符串文字和赋值的逻辑都会引发问题。但 Sona
Rosettacode.org 在 Ruby 中有这个出色的单行 FizzBuzz 解决方案。 1.upto(100){|n|puts'FizzBuzz '[i=n**4%-15,i+13]||n
很多时候我使用了这个命令,它在当前目录打开了一个临时的 HTTP 服务器: python3 -m http.server 现在我需要接收文件,有没有打开ftp服务器的一行命令? 我只是在寻找一个命令行
相关主题 std::unique_ptr, deleters and the Win32 API 要将 Win32 句柄用作 RAII,我可以使用以下行 std::unique_ptr::type,
我认为必须有一个单行 Guava 解决方案来将一个不可变列表转换为另一个不可变列表,但我找不到它。假设我们有以下对象: ImmutableList input = ImmutableList.of("
我有以下 Highcharts ( http://www.highcharts.com ) 散点图。请注意,轴从 -10 开始,到 10 停止,中间为 0。我希望每条 0 线的宽度或颜色都与其他线不同
我有一个项目需要将一个视频文件与另一个音频文件合并。预期的输出是一个视频文件,其中包含来自实际视频的音频和合并后的音频文件。输出视频文件的长度将与实际视频文件的大小相同。 是否有单行 FFMPEG 命
我在 python3 类中有 2 个列表: self.keys = ["a","b","c","d"] self.values = [1,2,3,4] len(self.keys) == len(se
我有一个不同长度的数组列表,我想将它们组合成一个最大维度的矩阵,并在末尾填充零。例如(伪代码): combine( [1,2,3], [4,5]) [[1,2,3],[4,5,0]] 这是我目前的解决
例如,给定 i=5 和 n=8,我想生成 [0;0;0;0;1;0; 0;0]。具体来说,我想生成向量 v 以便: v = zeros(n,1); v(i) = 1; 有没有一种(合理的)方法可以在一
我是一名优秀的程序员,十分优秀!