#02静态TLS--thread local storage的使用

文章介绍了TLS(线程局部存储)的概念,它允许每个线程拥有自己的变量副本,确保线程安全。静态TLS在Windows下使用`__declspec(thread)`,在Linux下旧版用`__thread`,新版支持C11和C++11的`thread_local`关键字。静态TLS生成的代码执行效率高,但不适用于动态加载库,而动态TLS虽然支持所有变量但运行时成本较高。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

        项目需要使用到TLS来实现每个线程独占一定的资源。

        通过TLS定义的变量为所在线程独有,其他线程无法访问到,当线程结束后,TLS变量也随之释放。

        TLS 分为静态的和动态方式两种,是指 TLS 的访问模型,即编译器如何生成代码来访问 TLS 变量。静态 TLS 模型生成更快的代码,但是不能在进程启动后动态加载的库中引用 TLS 变量(即不能支持某些需要动态加载的库)。动态 TLS 模型可以引用所有的 TLS 变量,但是需要更多的运行时开销。静态 TLS 模型使用固定的偏移量来访问 TLS 变量,而动态 TLS 模型使用间接寻址或重定位来访问 TLS 变量。

这里只介绍静态TLS的使用方法。

Windows下:

__declspec(thread) int tls_i = 1;

Linux下:

旧版:

extern __thread int i;

static __thread struct state s;

__thread char *p;

C11或C++11新版:

 thread_local int tls_i = 1;

在Windows下,C语言可以通过Windows API来实现线程本地存储(Thread-Local StorageTLS)。以下是一个简单的示例代码来演示如何在Windows下使用C语言实现线程本地存储。 ```c #include <windows.h> // 声明线程本地存储变量 __declspec(thread) int tls_variable; // 线程函数 DWORD WINAPI ThreadFunction(LPVOID lpParam) { // 设置线程本地存储变量的值 tls_variable = 42; // 在线程内部访问线程本地存储变量的值 printf("Thread local variable value: %d\n", tls_variable); return 0; } int main() { HANDLE hThread; // 创建一个线程 hThread = CreateThread(NULL, 0, ThreadFunction, NULL, 0, NULL); if (hThread == NULL) { printf("Failed to create thread\n"); return 1; } // 等待线程结束 WaitForSingleObject(hThread, INFINITE); // 关闭线程句柄 CloseHandle(hThread); return 0; } ``` 在上面的示例代码中,我们使用`__declspec(thread)`关键字来声明一个线程本地存储变量`tls_variable`。在`ThreadFunction`线程函数中,我们设置了线程本地存储变量的值为42,并在线程内部打印了变量的值。 需要注意的是,使用`__declspec(thread)`关键字声明的线程本地存储变量只能是静态或全局变量,不能是局部变量。 编译运行上述代码后,你会看到输出中显示了线程本地存储变量的值为42。这证明了在线程之间,每个线程都有自己独立的线程本地存储空间。 这只是一个简单的示例,实际应用中,你可以根据需要在线程函数中使用线程本地存储来存储和访问特定于每个线程的数据。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值