0%

gcc 关键字__thread

gcc 关键字__thread

__thread

Thread Local Storage:线程局部存储(tls)分配的变量,每个当前线程有一个该变量的实例。__thread 是 gcc 内置的线程局部存储设施,其存储效率可以和全局变量相比;__thread 变量在每一个线程中都有一份独立实例,各线程值是互不干扰的。
可以用来修饰那些带有全局性且值可能变,但是又不值得用全局变量保护的变量。只能修饰 POD 类型(类似整型指针的标量,不带自定义的构造、拷贝、赋值、析构的类型,二进制内容可以任意复制 memset,memcpy,且内容可以复原)。
不能修饰 class 类型,因为无法自动调用构造和析构函数可用于修饰全局变量,函数内的静态变量,不能修饰函数的局部变量或 class 的普通成员变量。且__thread 变量值只能初始化为编译器常量。

注意:
__thread 限定符(specifier)可以单独使用,也可带有 extern 或 static 限定符,但不能带有其它存储类型的限定符。
__thread 可用于全局的静态文件作用域,静态函数作用域或一个类中的静态数据成员。不能用于块作用域,自动或非静态数据成员。

使用举例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#include <iostream>
#include <pthread.h>
#include <unistd.h>

__thread int i = 0;

void* f1(void* arg)
{
i++;
printf("f1 i address %p val %d\n", &i, i);
}

void* f2(void* arg)
{
i += 2;
printf("f2 i address %p val %d\n", &i, i);

}

int main()
{
pthread_t pid1, pid2;
i += 3;
pthread_create(&pid1, NULL, f1, NULL);
pthread_create(&pid2, NULL, f2, NULL);
pthread_join(pid1, NULL);
pthread_join(pid2, NULL);
printf("main i address %p val %d\n", &i, i);

return 0;
}

结果:

注意,f1 和 f2 中的地址并不相同