C 11 中的线程局部变量:自动静态?
在 C 11 中,thread_local 变量是管理数据的强大机制,每个执行线程都是唯一的。然而,出现了一个常见的问题:它们是否自动被视为静态?为了回答这个问题,让我们检查两个代码段:
代码段 1
<code class="cpp">void f() { thread_local vector<int> V; V.clear(); ... // use V as a temporary variable }</code>
代码段 2
<code class="cpp">void f() { static thread_local vector<int> V; V.clear(); ... // use V as a temporary variable }</code>
C 标准提供了明确的答案:
根据标准:
当 thread_local 应用于块作用域的变量时,存储类说明符static 如果没有显式出现,则表示它是隐含的。
因此,代码段 1 相当于代码段 2。但这并不意味着 thread_local 和 static 变量可以互换。
线程局部变量与静态变量
虽然 thread_local 变量意味着静态存储,但它们与静态变量有根本的区别:
所有用thread_local 关键字有_线程存储持续时间_。这些实体的存储在创建它们的线程的持续时间内持续存在。每个线程都有一个不同的对象或引用,并且使用声明的名称引用与当前线程关联的实体。
本质上,线程存储持续时间确保每个线程都有其thread_local 变量的自己的实例。这与静态变量形成对比,静态变量在进程中的所有线程之间共享。
多线程的含义
正如最初的问题所示,thread_local 变量可用于替换多线程程序中的静态变量,消除潜在的竞争条件和数据争用。但是,请务必记住,thread_local 变量不能跨线程共享,并且仅应在需要特定于线程的数据时使用。
以上是C 11 中的线程局部变量是否自动被视为静态变量?的详细内容。更多信息请关注PHP中文网其他相关文章!