C/C++ 线程局部存储(TLS)

在C或C++中,线程局部存储(Thread-Local Storage,简称TLS)是一种用于存储线程特有数据的方法。这意味着每个线程都可以访问它自己的变量实例,而不会影响到其他线程中的同名变量。这在多线程程序中非常有用,因为它可以避免对共享数据的竞争和同步开销。

C++11引入了thread_local关键字来简化线程局部存储的使用。在C中,则需要依赖操作系统或编译器提供的特定机制,如GCC的__thread关键字。

C++11中的thread_local示例

下面是一个C++11中使用thread_local的简单例子:

cpp 复制代码
#include <iostream>
#include <thread>
#include <vector>

// 定义一个线程局部的整型变量
thread_local int tls_counter = 0;

void increment_counter() {
    tls_counter++; // 每个线程都会独立地增加自己的tls_counter
    std::cout << "Thread " << std::this_thread::get_id() << " incremented tls_counter to " << tls_counter << std::endl;
}

int main() {
    std::vector<std::thread> threads;

    // 创建10个线程
    for (int i = 0; i < 10; ++i) {
        threads.emplace_back(increment_counter);
    }

    // 等待所有线程完成
    for (auto& th : threads) {
        th.join();
    }

    return 0;
}

输出:

txt 复制代码
Thread 140517560022592 incremented tls_counter to 1
Thread 140517551629888 incremented tls_counter to 1
Thread 140517534844480 incremented tls_counter to 1
Thread 140517543237184 incremented tls_counter to 1
Thread 140517409019456 incremented tls_counter to 1
Thread 140517526451776 incremented tls_counter to 1
Thread 140517518059072 incremented tls_counter to 1
Thread 140517438387776 incremented tls_counter to 1
Thread 140517429995072 incremented tls_counter to 1
Thread 140517421602368 incremented tls_counter to 1

在这个例子中,tls_counter是一个线程局部变量,每个线程都会拥有自己的tls_counter实例。因此,尽管所有线程都调用了increment_counter函数,但每个线程都会独立地增加自己的tls_counter,而不会影响到其他线程的tls_counter

GCC的__thread在C中的示例

对于C语言,可以使用GCC的__thread关键字来实现类似的功能:

c 复制代码
#include <stdio.h>
#include <pthread.h>
#include <stdlib.h>

// 定义一个线程局部的整型变量
__thread int tls_counter = 0;

void* increment_counter(void* arg) {
    tls_counter++; // 每个线程都会独立地增加自己的tls_counter
    printf("Thread %ld incremented tls_counter to %d\n", (long)pthread_self(), tls_counter);
    return NULL;
}

int main() {
    pthread_t threads[10];

    // 创建10个线程
    for (int i = 0; i < 10; ++i) {
        pthread_create(&threads[i], NULL, increment_counter, NULL);
    }

    // 等待所有线程完成
    for (int i = 0; i < 10; ++i) {
        pthread_join(threads[i], NULL);
    }

    return 0;
}
txt 复制代码
Thread 127565616375360 incremented tls_counter to 1
Thread 127565599589952 incremented tls_counter to 1
Thread 127565624768064 incremented tls_counter to 1
Thread 127565582804544 incremented tls_counter to 1
Thread 127565607982656 incremented tls_counter to 1
Thread 127565591197248 incremented tls_counter to 1
Thread 127565574411840 incremented tls_counter to 1
Thread 127565477959232 incremented tls_counter to 1
Thread 127565486351936 incremented tls_counter to 1
Thread 127565494744640 incremented tls_counter to 1

这个例子与C++的例子类似,但使用了C的pthread库来创建和管理线程,并使用__thread关键字来声明线程局部变量。

注意,虽然__thread在GCC中非常有用,但它并不是C语言标准的一部分,因此在使用时需要考虑跨平台兼容性问题。

相关推荐
郝学胜-神的一滴20 小时前
跨平台动态库与头文件:从原理到命名的深度解析
linux·c++·程序人生·unix·cmake
代码中介商20 小时前
C++ 仿函数(Functor)深度解析:从基础到应用
开发语言·c++
王老师青少年编程20 小时前
csp信奥赛C++高频考点专项训练之字符串 --【字符串基础】:[NOIP 2018 普及组] 标题统计
c++·字符串·csp·高频考点·信奥赛·专项训练·标题统计
冯诺依曼的锦鲤20 小时前
从零实现高并发内存池:TCMalloc 核心架构拆解
c++·学习·算法·架构
无忧.芙桃21 小时前
C++IO库的超详细讲解
开发语言·c++
爱看书的小沐1 天前
【小沐学GIS】基于C++渲染三维飞行仿真Flight Simulation(OpenGL )第十三期
c++·qt·webgl·opengl·飞行仿真·flight
你撅嘴真丑1 天前
最大质因子序列
c++
努力努力再努力wz1 天前
【MySQL进阶系列】一文打通事务机制:从锁、Undo Log 到 MVCC 与隔离级别
c语言·数据结构·数据库·c++·mysql·算法·github
薇茗1 天前
【初阶数据结构】 左右逢源的分支诗律 二叉树1
c语言·数据结构·算法
澈2071 天前
C++ string全面解析:从入门到精通
数据结构·c++·算法