c++ - 为什么 volatile 不是 sig_atomic_t 的一部分

标签 c++ signals volatile

在我的平台(X86、Fedora、gcc 9.1.1)上,sig_atomic_t 类型定义为普通的 int

在 C++ 标准中,sig_atomic_t 始终与 volatile 限定符一起使用。
我明白为什么需要 volatile,但为什么它不是类型的一部分呢?

类似于:

using sig_atomic_t = volatile int;

最佳答案

这是从C继承的。C定义,同时允许sig_atomic_t要 volatile 合格,不需要它。我看过的标准文档 (N1570) 中使用的所有示例都以 volatile sig_atomic_t 的形式给出。 .

现在使用 std:atomic 可能会更好以及 <atomic> 中指定的其他功能标题 when feasible . (另请参阅 cppreference 上的 sig_atomic_t。)

关于c++ - 为什么 volatile 不是 sig_atomic_t 的一部分,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56612893/

相关文章:

c++ - C++多线程程序中的串行代码执行

audio - fscanf(文件指针, "%d\n%lg\n",sig_length,sample_rate);怎么解释呢?

c++ - 从线程安全地发出信号并将其连接到小部件

c++ - 在这里删除 c++ volatile 是否安全?

c - 关键部分中使用的资源是否需要 volatile?

c++ - 它是安全锁/范围保护实现吗?

c++ - 计算常量的函数的编译时评估

c++ - 用于检测由于类型提升导致的无限循环的静态分析工具?

c - 这里使用信号的方式背后的想法是什么?

asp.net - 为什么/何时 session 写入容易受到线程终止的影响?