转载请说明出处:http://blog.csdn.net/cywosp/article/details/26876231

   
在Linux中另一种更为高效的线程局部存储方法,就是使用keyword__thread来定义变量。__thread是GCC内置的线程局部存储设施(Thread-Local Storage),它的实现很高效。与pthread_key_t向比較更为高速。其存储性能能够与全局变量相媲美,并且使用方式也更为简单。创建线程局部变量仅仅需简单的在全局或者静态变量的声明中增加__thread说明就可以。列如:
    static __thread char t_buf[32]
= {'\0'};
    extern __thread int t_val
= 0;
凡是带有__thread的变量,每一个线程都拥有该变量的一份拷贝。且互不干扰。线程局部存储中的变量将一直存在,直至线程终止。当线程终止时会自己主动释放这一存储。__thread并非全部数据类型都能够使用的。由于其仅仅支持POD(Plain
old data structure)[1]类型。不支持class类型——其不能自己主动调用构造函数和析构函数。

同一时候__thread能够用于修饰全局变量、函数内的静态变量,可是不能用于修饰函数的局部变量或者class的普通成员变量。另外。__thread变量的初始化仅仅能用编译期常量。比如:

    __thread std::string t_object_1 ("Swift");
                  // 错误。由于不能调用对象的构造函数
    __thread std::string* t_object_2 = new std::string
(); // 错误,初始化必须用编译期常量
    __thread std::string* t_object_3 = nullptr;
               // 正确,可是须要手工初始化并销毁对象

除了以上之外。关于线程局部存储变量的声明和使用还需注意一下几点:
  1. 假设变量声明中使用量keywordstatic或者extern。那么keyword__thread必须紧随其后。
  2. 与一般的全局变量或静态变量一样。线程局部变量在声明时能够设置一个初始化值。
  3. 能够使用C语言取地址符(&)来获取线程局部变量的地址。
__thread的使用样例可參考https://github.com/ApusApp/Swift/blob/master/swift/base/logging.cpp的实现及其单元測试对于那些非POD数据类型。假设想使用线程局部存储机制。能够使用对pthread_key_t封装的类来处理。详细方式可參考https://github.com/ApusApp/Swift/blob/master/swift/base/threadlocal.h的实现以及其的单元測试


參考
[1] http://zh.wikipedia.org/wiki/POD_(%E7%A8%8B%E5%BA%8F%E8%AE%BE%E8%AE%A1)
[2] Linux/UNIX系统编程手冊(上)
[3] Linux多线程服务端编程使用muduo C++网络库





每天进步一点点——Linux中的线程局部存储(二)的更多相关文章

  1. 每天进步一点点——Linux中的线程局部存储(一)

    转载请说明出处:http://blog.csdn.net/cywosp/article/details/26469435    在Linux系统中使用C/C++进行多线程编程时,我们遇到最多的就是对同 ...

  2. linux中的线程局部存储(TLS)

    http://blog.csdn.net/cywosp/article/details/26469435

  3. C#中的线程(二)线程同步

    C#中的线程(二)线程同步   Keywords:C# 线程Source:http://www.albahari.com/threading/Author: Joe AlbahariTranslato ...

  4. 在Linux中使用线程

    我并不假定你会使用Linux的线程,所以在这里就简单的介绍一下.如果你之前有过多线程方面的编程经验,完全可以忽略本文的内容,因为它非常的初级. 首先说明一下,在Linux编写多线程程序需要包含头文件p ...

  5. Linux中-POSIX 线程详解

    一种支持内存共享的简捷工具   摘自https://www.ibm.com/developerworks/cn/linux/thread/posix_thread1/ 线程是有趣的 了解如何正确运用线 ...

  6. Linux中epoll+线程池实现高并发

    服务器并发模型通常可分为单线程和多线程模型,这里的线程通常是指“I/O线程”,即负责I/O操作,协调分配任务的“管理线程”,而实际的请求和任务通常交由所谓“工作者线程”处理.通常多线程模型下,每个线程 ...

  7. 每天进步一点点——Linux中的文件描写叙述符与打开文件之间的关系

    转载请说明出处:http://blog.csdn.net/cywosp/article/details/38965239 1. 概述     在Linux系统中一切皆能够看成是文件,文件又可分为:普通 ...

  8. linux中的线程同步:生产者、消费者问题

    #include <stdio.h> #include <semaphore.h> #include <unistd.h> #include <stdlib. ...

  9. C#中的线程(二)线程同步基础 (读后感)

    参考文章:https://www.cnblogs.com/dingfangbo/p/5769501.html 一.lock 确保只有一个线程访问某个资源或某段代码.通俗的讲就是多个线程操作相同的锁对象 ...

随机推荐

  1. 算法理论——PLA

    全称 perceptron learning algrithm 用武之地 二值分类问题,资料线性可分 算法核心(以二维平面为例) 找到一条直线WTX=0,一边全为+1,另一边全为-1.找到了这条线(即 ...

  2. Django底层原理简介与安装

    Django环境目录搭建一栏: 利用wsgiref模块封装好的socket搭建服务端: #利用wsgiref模块封装好的socket演示操作(例如accept\recv) #也可以实现socket服务 ...

  3. 设计模式(二 & 三)工厂模式:1-简单工厂模式

    模拟场景: 需要构造一个运算器(Operation),分别负责加减乘除的运算功能. 思想: 这里需要构造四个 Operation,可以使用 Factory 去统一创建这四个对象. 所需要构造的对象是运 ...

  4. python多进程(multiprocessing)

    最近有个小课题,需要用到双进程,翻了些资料,还算圆满完成任务.记录一下~ 1.简单地双进程启动 同时的调用print1()和print2()两个打印函数,代码如下: #/usr/bin/python ...

  5. 性能学习之--loaderunner压测

    打开一个脚本,tools-create Controllwer Scenario,开始场景的设计 一.场景设计--手工测试 1.初始化 2.start vu 一般选择simultaneously,用户 ...

  6. python基于SQLAlchemy的DBtools

    新版,只创建一次线程池 # -*- coding: utf-8 -*- from sqlalchemy import create_engine from sqlalchemy.orm import ...

  7. Java 学习(2):java 基础概念

    Java作为一种面向对象语言.支持以下基本概念: 多态 继承 封装 抽象 类 对象 实例 方法 重载 基础语法: 一个Java程序可以认为是一系列对象的集合,而这些对象通过调用彼此的方法来协同工作.以 ...

  8. poj 6243 Dogs and Cages

    Dogs and Cages Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)To ...

  9. FOJ Problem 2260 Card Game

                                                                                            Problem 2260 ...

  10. 【CF733F】Drivers Dissatisfaction(最小瓶颈生成树,倍增)

    题意:给出一个图,每条边有权值和花费c,每次花费c能使的权值-1.给出一个预算,求减完权值后的一个最小生成树. 思路:感谢CC大神 有这样一个结论:最佳方案里必定存在一种,预算全部花费全部分配在一条边 ...