多线程编程模式之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

相关文章

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

SpringBoot如何通过Map实现策略模式

《SpringBoot如何通过Map实现策略模式》策略模式是一种行为设计模式,它允许在运行时选择算法的行为,在Spring框架中,我们可以利用@Resource注解和Map集合来优雅地实现策略模式,这... 目录前言底层机制解析Spring的集合类型自动装配@Resource注解的行为实现原理使用直接使用M

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

Java使用多线程处理未知任务数的方案介绍

《Java使用多线程处理未知任务数的方案介绍》这篇文章主要为大家详细介绍了Java如何使用多线程实现处理未知任务数,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 知道任务个数,你可以定义好线程数规则,生成线程数去跑代码说明:1.虚拟线程池:使用 Executors.newVir

C#原型模式之如何通过克隆对象来优化创建过程

《C#原型模式之如何通过克隆对象来优化创建过程》原型模式是一种创建型设计模式,通过克隆现有对象来创建新对象,避免重复的创建成本和复杂的初始化过程,它适用于对象创建过程复杂、需要大量相似对象或避免重复初... 目录什么是原型模式?原型模式的工作原理C#中如何实现原型模式?1. 定义原型接口2. 实现原型接口3

JAVA封装多线程实现的方式及原理

《JAVA封装多线程实现的方式及原理》:本文主要介绍Java中封装多线程的原理和常见方式,通过封装可以简化多线程的使用,提高安全性,并增强代码的可维护性和可扩展性,需要的朋友可以参考下... 目录前言一、封装的目标二、常见的封装方式及原理总结前言在 Java 中,封装多线程的原理主要围绕着将多线程相关的操

大数据spark3.5安装部署之local模式详解

《大数据spark3.5安装部署之local模式详解》本文介绍了如何在本地模式下安装和配置Spark,并展示了如何使用SparkShell进行基本的数据处理操作,同时,还介绍了如何通过Spark-su... 目录下载上传解压配置jdk解压配置环境变量启动查看交互操作命令行提交应用spark,一个数据处理框架