多线程编程模式之Thread-Specific Storage模式

2024-01-10 00:08

本文主要是介绍多线程编程模式之Thread-Specific Storage模式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • Thread-Specific Storage
    • Thread-Specific Storage 介绍
    • Thread-Specific Storage 使用场景
    • Thread-Specific Storage 示例代码
    • Thread-Specific Storage 模式的理解

Thread-Specific Storage

Thread-Specific Storage 介绍

Thread-Specific Storage模式是即便只有一个入口,也会为内部每个线程分配特有的存储空间的模式;

在Java中,ThreadLocal类实现了该模式;

Thread-Specific Storage 使用场景

  1. 将原来单线程环境下进行的任务,迁移到多线程环境下进行,又不想对API做过多的修改时,可使用该模式实现平滑过渡;
  2. 线程持有的信息不会被其他线程所访问;

Thread-Specific Storage 示例代码

//对外提供API的任务代理类
public class Log {private static final ThreadLocal<TSLog> tsLogCollection=new ThreadLocal<TSLog>();public static void println(String s){getTSLog().println(s);}public static void close(){getTSLog().close();}private static TSLog getTSLog(){TSLog tsLog=tsLogCollection.get();if(tsLog==null){tsLog=new TSLog(Thread.currentThread().getName()+"-log.txt");tsLogCollection.set(tsLog);}return tsLog;}
}
//实际执行任务的类
public class TSLog {private PrintWriter writer=null;public TSLog(String fileName){try{writer=new PrintWriter(new FileWriter(fileName));}catch(IOException e){e.printStackTrace();}}public void println(String s){writer.println(s);}public void close(){writer.println("+++++++++End of Log");writer.close();}
}
//请求类
public class ClientThread extends Thread{public ClientThread(String name){super(name);}public void run(){System.out.println(getName()+ "BEGIN");for(int i=0;i<10;i++){Log.println("I="+i);try{Thread.sleep(100);}catch(InterruptedException e){e.printStackTrace();}}Log.close();System.out.println(getName()+" END");}
}
//入口类
public class Tester {public static void main(String[] args){new ClientThread("Alice").start();new ClientThread("Bobby").start();new ClientThread("Chris").start();}
}

Thread-Specific Storage 模式的理解

实际上,Thread-Specific Storage模式通过将所需信息保存在线程本地,避免了在多个线程之间共享数据,从而无需进行显式的互斥操作;之所以说是无需显式的互斥操作是因为,ThreadLocal——资源管理类可能会进行互斥操作;

使用Thread-Specific Storage模式有利于实现从单线程到多线程环境的迁移;

为多线程提供统一的功能入口,同时使用线程特定的信息,避免了调用者传入过多的参数,简化了程序;

这篇关于多线程编程模式之Thread-Specific Storage模式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java设计模式---迭代器模式(Iterator)解读

《Java设计模式---迭代器模式(Iterator)解读》:本文主要介绍Java设计模式---迭代器模式(Iterator),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录1、迭代器(Iterator)1.1、结构1.2、常用方法1.3、本质1、解耦集合与遍历逻辑2、统一

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

Redis Cluster模式配置

《RedisCluster模式配置》:本文主要介绍RedisCluster模式配置,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录分片 一、分片的本质与核心价值二、分片实现方案对比 ‌三、分片算法详解1. ‌范围分片(顺序分片)‌2. ‌哈希分片3. ‌虚

RabbitMQ工作模式中的RPC通信模式详解

《RabbitMQ工作模式中的RPC通信模式详解》在RabbitMQ中,RPC模式通过消息队列实现远程调用功能,这篇文章给大家介绍RabbitMQ工作模式之RPC通信模式,感兴趣的朋友一起看看吧... 目录RPC通信模式概述工作流程代码案例引入依赖常量类编写客户端代码编写服务端代码RPC通信模式概述在R

python多线程并发测试过程

《python多线程并发测试过程》:本文主要介绍python多线程并发测试过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、并发与并行?二、同步与异步的概念?三、线程与进程的区别?需求1:多线程执行不同任务需求2:多线程执行相同任务总结一、并发与并行?1、

SQL Server身份验证模式步骤和示例代码

《SQLServer身份验证模式步骤和示例代码》SQLServer是一个广泛使用的关系数据库管理系统,通常使用两种身份验证模式:Windows身份验证和SQLServer身份验证,本文将详细介绍身份... 目录身份验证方式的概念更改身份验证方式的步骤方法一:使用SQL Server Management S

Python多进程、多线程、协程典型示例解析(最新推荐)

《Python多进程、多线程、协程典型示例解析(最新推荐)》:本文主要介绍Python多进程、多线程、协程典型示例解析(最新推荐),本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 目录一、multiprocessing(多进程)1. 模块简介2. 案例详解:并行计算平方和3. 实现逻

Redis高可用-主从复制、哨兵模式与集群模式详解

《Redis高可用-主从复制、哨兵模式与集群模式详解》:本文主要介绍Redis高可用-主从复制、哨兵模式与集群模式的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录Redis高可用-主从复制、哨兵模式与集群模式概要一、主从复制(Master-Slave Repli