基于TLS(线程局部存储)的高效timelog实现

什么是timelog?

我们在分析程序性能的时候,会加入的一些logging信息记录每一部分的时间信息

timelog模块的功能就是提供统一的接口来允许添加和保存logging

我们正在用的timelog有几个缺点

1.固定大小,一旦满了就不能加入新的logging

2.每次进入就会有一个全局的lock锁住,非常影响性能

这两天基于boost的thread_specific_ptr和circular_buffer实现了一个高效的timelog,主要特点有

1. 几乎不需要任何lock,所以性能理论上会非常高(虽然俺没真正测试过)

2. 使用的是固定大小的环形队列,满了之后把会最老的信息抹去,所以不存在满了就不能加入logging的问题

代码

实现很简单

有一点缺陷,懒得改了

https://github.com/cutepig123/TestCpp/blob/master/cpp11test/1/mytimelog.cpp

Known issues

1) 所有timelog_create的timelog现在其实都指向同一个实现,所以无论create多少个其实东西都是一样的

2)线程局部存储里的东西不会自动释放,所以会有内存泄露(除非你的每个线程都用boost thread,具体参考boost文档)

如果程序的线程是固定的,那么没有什么影响

但当程序不停地新建删除线程的时候就会有严重问题

时间: 2024-08-06 13:10:49

基于TLS(线程局部存储)的高效timelog实现的相关文章

TLS 线程局部存储

thread local storage TLS 线程局部存储,布布扣,bubuko.com

TLS线程局部存储

0x01 TLS (Thread Local Storage) 为线程单独提供的私有空间 0x02 gcc中的隐式TLS使用方法 隐式TLS __thread int number; 显式TLS pthread_key_create pthread_getspecific pthread_setspecific pthread_key_delete 0x03 windows中的隐式TLS使用方法 隐式TLS __declspec(thread) int number; 显式TLS TlsAllo

线程局部存储 TLS

C/C++运行库提供了TLS(线程局部存储),在多线程还未产生时,可以将数据与正在执行的线程关联.strtok()函数就是一个很好的例子.与它一起的还有strtok_s(),_tcstok_s()等等函数,其实_tcs 是 wcs 的另外一种写法,表示宽字符存储,_s 是微软定义的安全函数,通常比普通函数多一个参数.以_tcstok_s()为例, int main(int argc, char* argv[]){ wchar_t Source[] = L"192.168.255.255"

线程局部存储TLS

1 .使用线程局部存储的理由 当我们希望这个进程的全局变量变为线程私有时,而不是所有线程共享的,也就是每个线程拥有一份副本时,这时候就可以用到线程局部存储(TLS,Thread Local Storage)这个机制了. 2.动态TLS(1)调用TlsAlloc函数  两种方式: 1>全局调用一次:   global_dwTLSindex=TLSAlloc(); 如果程序只调用一次TlsAlloc,而不是每个线程都调用一次TlsAlloc()函数的话,多个线程就使用同一个索引值,不同线程虽然看起来

【windows核心编程】线程局部存储TLS

线程局部存储TLS, Thread Local Storage TLS是C/C++运行库的一部分,而非操作系统的一部分. 分为动态TSL 和 静态TLS 一.动态TLS 应用程序通过调用一组4个函数来使用动态TLS, 这些函数实际上最为DLL所使用. 系统中的每个进程都有一组 正在使用标志(in-use flag), 每个标志可被设置为FREE 或者 INUSE, 表示该TLS元素是否正在使用. 微软平台保证至少有TLS_MINUMUM_AVALIABLE个标志位可供使用, TLS_MINUMU

线程局部存储(TLS)

线程局部存储(TLS) 2011-10-11 09:59:28|  分类: Win32---API |  标签:tls   |举报 |字号 订阅 什么是线程局部存储 众所周知,线程是执行的单元,同一个进程内的多个线程共享了进程的地址空间,线程一般有自己的栈,但是如果想要实现某个全局变量在不同的线程之间取不同的值,而且不受影响.一种办法是采用线程的同步机制,如对这个变量的读写之处加临界区或者互斥量,但是这是以牺牲效率为代价的,能不能不加锁呢?线程局部存储(TLS)就是干这个的. 虽然TLS 很方便

使用线程局部存储实现多线程下的日志系统(转)

http://www.ibm.com/developerworks/cn/linux/1310_qianbh_threadlog/index.html 多线程编程向来不容易,在多线程环境下实现日志系统是很多程序员亟须解决的问题.在本文中详细介绍了线程局部存储的概念.原理,并用代码示例详细展示了如何使用线程局部存储来实现多线程下的日志系统. 概述 通常来说,在应用程序中需要日志来记录程序运行的状态,以便后期问题的跟踪定位.在日志系统的设计中,通常会有一个总的日志系统来统一协调这些日志的设置如位置.

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

转载请说明出处:http://blog.csdn.net/cywosp/article/details/26469435 在Linux系统中使用C/C++进行多线程编程时,我们遇到最多的就是对同一变量的多线程读写问题,大多情况下遇到这类问题都是通过锁机制来处理,但这对程序的性能带来了很大的影响,当然对于那些系统原生支持原子操作的数据类型来说,我们可以使用原子操作来处理,这能对程序的性能会得到一定的提高.那么对于那些系统不支持原子操作的自定义数据类型,在不使用锁的情况下如何做到线程安全呢?本文将从

设计自己的线程局部存储

参考资料 王艳平 <Windows程序设计> #pragma once #include <windows.h> #include <stddef.h> #include<iostream> using namespace std; class CNoTrackObject; class CSimpleList//将每个线程的私有数据的首地址串联起来 { public: CSimpleList(int NextOffset = 0); void Constr