《Java工程师必读手册》——Java编程技巧系列——Java编程技巧之数据结构(2)

简介: 《Java工程师必读手册》——Java编程技巧系列——Java编程技巧之数据结构(2)

接上篇:https://developer.aliyun.com/article/1228152?spm=a2c6h.13148508.setting.25.21084f0eNCKPti


三、 使用ThreadLocal存储线程专有对象

 

ThreadLocal提供了线程专有对象,可以在整个线程生命周期中随时取用,极大地方便了一些逻辑的实现。

 

常见的ThreadLocal用法主要有两种:

 

保存线程上下文对象,避免多层级参数传递;

保存非线程安全对象,避免多线程并发调用。

 

1. 保存线程上下文对象,避免多层级参数传递

 

这里,以PageHelper插件的源代码中的分页参数设置与使用为例说明。

 

1) 设置分页参数代码

 

image.png

 

 

 

2) 使用分页参数代码

 

image.png

 

3) 使用分页插件代码

 

image.png 

 

如果要把分页参数通过函数参数逐级传给查询语句,除非修改MyBatis相关接口函数,否则是不可能实现的。

 

2. 保存非线程安全对象,避免多线程并发调用

 

在写日期格式化工具函数时,首先想到的写法如下:

 

image.png 

 

其中,每次调用都要初始化DateFormat导致性能较低,把DateFormat定义成常量后的写法如下:

 

image.png 

 

由于SimpleDateFormat是非线程安全的,当多线程同时调用formatDate函数时,会导致返回结果与预期不一致。如果采用ThreadLocal定义线程专有对象,优化后的代码如下:

 

image.png 

 

这是在没有线程安全的日期格式化工具类之前的实现方法。在JDK8以后,建议使用DateTimeFormatter代替SimpleDateFormat,因为SimpleDateFormat是线程不安全的,而DateTimeFormatter是线程安全的。当然,也可以采用第三方提供的线程安全日期格式化函数,比如apache的DateFormatUtils工具类。

 

注意

ThreadLocal有一定的内存泄露的风险,尽量在业务代码结束前调用remove函数进行数据清除。


 接下篇:https://developer.aliyun.com/article/1228148?groupCode=java

相关文章
|
16天前
|
存储 安全 Java
Java程序员必须掌握的数据结构:HashMap
HashMap底层原理实现是每个Java Boy必须掌握的基本技能,HashMap也是业务开发每天都需要遇到的好伙伴。如此基础且核心的底层数据结构,JDK也给其赋予了线程安全的功能,我们来看看~
31 2
Java程序员必须掌握的数据结构:HashMap
|
17天前
|
存储 安全 Java
Java并发编程中的高效数据结构:ConcurrentHashMap解析
【4月更文挑战第25天】在多线程环境下,高效的数据访问和管理是至关重要的。Java提供了多种并发集合来处理这种情境,其中ConcurrentHashMap是最广泛使用的一个。本文将深入分析ConcurrentHashMap的内部工作原理、性能特点以及它如何在保证线程安全的同时提供高并发性,最后将展示其在实际开发中的应用示例。
|
23天前
|
存储 供应链 Java
《Java 简易速速上手小册》第3章:Java 数据结构(2024 最新版)
《Java 简易速速上手小册》第3章:Java 数据结构(2024 最新版)
9 1
|
24天前
|
Java 测试技术 索引
滚雪球学Java(14):快速入门JavaSE-for循环语句,轻松掌握编程技巧
【4月更文挑战第3天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
30 1
滚雪球学Java(14):快速入门JavaSE-for循环语句,轻松掌握编程技巧
|
29天前
|
人工智能 Kubernetes Java
Java开发工程师如何紧跟技术前沿对于保持专业竞争力、提升工作效率以及适应行业发展?
【4月更文挑战第4天】Java开发工程师如何紧跟技术前沿对于保持专业竞争力、提升工作效率以及适应行业发展?
25 4
|
29天前
|
Java API
编码的奇迹:Java 21引入有序集合,数据结构再进化
编码的奇迹:Java 21引入有序集合,数据结构再进化
18 0
|
2月前
|
XML 存储 算法
Java数据结构与算法-java数据结构与算法(五)
Java数据结构与算法-java数据结构与算法
51 0
|
4月前
|
存储 算法 Java
Java数据结构之链表及其常见算法
Java数据结构之链表及其常见算法
16 0
|
9月前
|
存储 Java
Java数据结构之第五章、LinkedList与链表
由于其底层是一段连续空间,当在ArrayList任意位置插入或者删除元素时,就需要将后序元素整体往前或者往后搬移,时间复杂度为O(n),效率比较低,因此ArrayList不适合做任意位置插入和删除比较多的场景。
47 0
|
10月前
|
Java
(四)Java数据结构之双链表
其实和单链表差不多,以下代码实现了增删改查:
49 0