base10. ThreadLocalSingleton线程本地单例模板类

2024-03-10 21:58

本文主要是介绍base10. ThreadLocalSingleton线程本地单例模板类,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ThreadLocalSingleton类图

在这里插入图片描述
数据成员:

static _thread T* t_value:一个类型是T的线程本地指针t_value,该指针是POD类型,故线程本地存储可以用__thread关键字
static Deleter deleter
:一个类型是Deleter的deleter_对象,deleter_对象主要是为了能够调用destructor使得t_value_可以被自动释放

成员函数:

static T& instance():返回单例对象t_value_的引用,调用deleter_.set()使得t_value_可以被自动销毁,因为每个线程都有一个指针,因此不需要额外考虑线程安全
static T* pointer():返回单例对象t_value_的指针
static void destructor(void* obj):调用delete函数销毁单例对象t_value_

Deleter类图
在这里插入图片描述
数据成员:

pthread_key_t pkey_:一个指向线程特定数据的pthread_key_t类型的pkey_对象

成员函数:

Deleter():构造函数,调用pthread_key_create()创建pkey_,并注册销毁函数destructor()
~Deleter():析构函数,调用pthread_key_delete()销毁pkey_
void set(T* newObj):调用pthread_setspecific可以为t_value_设置线程特定绑定

ThreadLocalSingleton.h

//线程本地单例类封装ThreadLocalSingleton.h
#ifndef MUDUO_BASE_THREADLOCALSINGLETON_H
#define MUDUO_BASE_THREADLOCALSINGLETON_H#include <boost/noncopyable.hpp>
#include <assert.h>
#include <pthread.h>namespace muduo
{template<typename T>
class ThreadLocalSingleton : boost::noncopyable
{public://返回单例对象t_value_的引用,因为每个线程都有一个指针,因此不需要额外考虑线程安全static T& instance(){if (!t_value_){t_value_ = new T();//调用deleter_.set()使得t_value_可以被自动销毁deleter_.set(t_value_);}return *t_value_;}//返回单例对象t_value_的指针static T* pointer(){return t_value_;}private://调用delete函数销毁单例对象t_value_static void destructor(void* obj){assert(obj == t_value_);typedef char T_must_be_complete_type[sizeof(T) == 0 ? -1 : 1];delete t_value_;t_value_ = 0;}//嵌套类Deleter,该类目的是在t_value_对象销毁时自动回调destructor()函数class Deleter{public:Deleter(){pthread_key_create(&pkey_, &ThreadLocalSingleton::destructor);}~Deleter(){pthread_key_delete(pkey_);}void set(T* newObj){assert(pthread_getspecific(pkey_) == NULL);pthread_setspecific(pkey_, newObj);}pthread_key_t pkey_;};//一个类型是T的线程本地指针t_value_,该指针是POD类型,故线程本地存储可以用__thread关键字static __thread T* t_value_;//一个类型是Deleter的deleter_对象,deleter_对象主要是为了能够调用destructor使得t_value_可以被自动释放static Deleter deleter_;
};template<typename T>
__thread T* ThreadLocalSingleton<T>::t_value_ = 0;template<typename T>
typename ThreadLocalSingleton<T>::Deleter ThreadLocalSingleton<T>::deleter_;}
#endif

这篇关于base10. ThreadLocalSingleton线程本地单例模板类的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/795652

相关文章

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

Java中实现线程的创建和启动的方法

《Java中实现线程的创建和启动的方法》在Java中,实现线程的创建和启动是两个不同但紧密相关的概念,理解为什么要启动线程(调用start()方法)而非直接调用run()方法,是掌握多线程编程的关键,... 目录1. 线程的生命周期2. start() vs run() 的本质区别3. 为什么必须通过 st

Linux实现线程同步的多种方式汇总

《Linux实现线程同步的多种方式汇总》本文详细介绍了Linux下线程同步的多种方法,包括互斥锁、自旋锁、信号量以及它们的使用示例,通过这些同步机制,可以解决线程安全问题,防止资源竞争导致的错误,示例... 目录什么是线程同步?一、互斥锁(单人洗手间规则)适用场景:特点:二、条件变量(咖啡厅取餐系统)工作流

Java中常见队列举例详解(非线程安全)

《Java中常见队列举例详解(非线程安全)》队列用于模拟队列这种数据结构,队列通常是指先进先出的容器,:本文主要介绍Java中常见队列(非线程安全)的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一.队列定义 二.常见接口 三.常见实现类3.1 ArrayDeque3.1.1 实现原理3.1.2

SpringBoot3中使用虚拟线程的完整步骤

《SpringBoot3中使用虚拟线程的完整步骤》在SpringBoot3中使用Java21+的虚拟线程(VirtualThreads)可以显著提升I/O密集型应用的并发能力,这篇文章为大家介绍了详细... 目录1. 环境准备2. 配置虚拟线程方式一:全局启用虚拟线程(Tomcat/Jetty)方式二:异步

如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socket read timed out的问题

《如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socketreadtimedout的问题》:本文主要介绍解决Druid线程... 目录异常信息触发场景找到版本发布更新的说明从版本更新信息可以看到该默认逻辑已经去除总结异常信息触发场景复

Java实现本地缓存的常用方案介绍

《Java实现本地缓存的常用方案介绍》本地缓存的代表技术主要有HashMap,GuavaCache,Caffeine和Encahche,这篇文章主要来和大家聊聊java利用这些技术分别实现本地缓存的方... 目录本地缓存实现方式HashMapConcurrentHashMapGuava CacheCaffe

Maven项目打包时添加本地Jar包的操作步骤

《Maven项目打包时添加本地Jar包的操作步骤》在Maven项目开发中,我们经常会遇到需要引入本地Jar包的场景,比如使用未发布到中央仓库的第三方库或者处理版本冲突的依赖项,本文将详细介绍如何通过M... 目录一、适用场景说明​二、核心操作命令​1. 命令格式解析​2. 实战案例演示​三、项目配置步骤​1

使用Python实现调用API获取图片存储到本地的方法

《使用Python实现调用API获取图片存储到本地的方法》开发一个自动化工具,用于从JSON数据源中提取图像ID,通过调用指定API获取未经压缩的原始图像文件,并确保下载结果与Postman等工具直接... 目录使用python实现调用API获取图片存储到本地1、项目概述2、核心功能3、环境准备4、代码实现

Java如何根据word模板导出数据

《Java如何根据word模板导出数据》这篇文章主要为大家详细介绍了Java如何实现根据word模板导出数据,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... pom.XML文件导入依赖 <dependency> <groupId>cn.afterturn</groupId>