当前位置: 首页 > article >正文

单元测试中创建多个线程测试 ThreadLocal

单元测试中创建多个线程测试 ThreadLocal

在单元测试中,可以通过以下方式创建多个线程来测试 ThreadLocal 的行为。

目标

验证 ThreadLocal 在多线程环境下是否能正确隔离每个线程的数据。

实现步骤

  1. 定义需要测试的类
    包含 ThreadLocal 对象的类,提供设置和获取 ThreadLocal 数据的方法。

  2. 创建多线程测试方法
    使用 ExecutorService 或直接创建多个线程,分别访问和操作 ThreadLocal 数据。

  3. 验证结果
    每个线程的数据应相互隔离,互不影响。

示例代码

import org.junit.jupiter.api.Test;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

import static org.junit.jupiter.api.Assertions.assertEquals;

public class ThreadLocalTest {

    // 被测试的类,包含 ThreadLocal
    static class ThreadLocalDemo {
        private static final ThreadLocal<String> threadLocal = ThreadLocal.withInitial(() -> "default");

        public void set(String value) {
            threadLocal.set(value);
        }

        public String get() {
            return threadLocal.get();
        }

        public void remove() {
            threadLocal.remove();
        }
    }

    @Test
    public void testThreadLocalIsolation() throws InterruptedException {
        ThreadLocalDemo demo = new ThreadLocalDemo();
        int numThreads = 5; // 创建5个线程
        ExecutorService executor = Executors.newFixedThreadPool(numThreads);

        // 用于存储线程执行结果
        List<String> results = new ArrayList<>();
        List<Thread> threads = new ArrayList<>();

        // 创建并启动多个线程
        for (int i = 0; i < numThreads; i++) {
            final int threadId = i;
            executor.submit(() -> {
                String threadName = "Thread-" + threadId;
                demo.set(threadName); // 设置 ThreadLocal 数据
                results.add(demo.get()); // 获取并存储 ThreadLocal 数据
                demo.remove(); // 清理 ThreadLocal 数据
            });
        }

        // 关闭线程池并等待任务完成
        executor.shutdown();
        while (!executor.isTerminated()) {
            Thread.sleep(100);
        }

        // 验证每个线程的结果
        for (int i = 0; i < numThreads; i++) {
            assertEquals("Thread-" + i, results.get(i));
        }
    }
}

代码详解

  1. ThreadLocalDemo

    • 定义了一个 ThreadLocal 对象。
    • 提供 set, get, 和 remove 方法操作 ThreadLocal
  2. 线程池创建

    • 使用 ExecutorService 提供线程池,便于管理多个线程的执行。
    • 每个线程独立操作 ThreadLocal
  3. 结果验证

    • 在主线程中验证每个线程的数据是否与预期一致。
    • assertEquals 检查线程隔离是否成功。

注意事项

  1. 线程安全
    results 使用 ArrayList,在多线程中写入时需要考虑线程安全性,可以使用 Collections.synchronizedList 或类似机制。

  2. 资源清理
    测试结束后调用 ThreadLocal.remove(),避免内存泄漏。

  3. 并发问题
    使用 ExecutorService 可以避免直接使用 Thread 带来的管理复杂性。

通过上述代码,可以验证 ThreadLocal 的隔离性及其在多线程环境中的行为。如果出现问题,可以进一步分析线程间的数据传递逻辑是否正确。



http://www.kler.cn/a/460107.html

相关文章:

  • API多并发识别、C#文字识别
  • 国产编辑器EverEdit - 常用资源汇总
  • 【SpringBoot】多数据源事务卡死@DSTransactional,当某一个数据库挂掉了,系统卡死问题解决
  • 【人工智能机器学习基础篇】——深入详解深度学习之复杂网络结构:卷积神经网络(CNN)、循环神经网络(RNN)、生成对抗网络(GAN)等概念及原理
  • 面试题:@Transactional 注解在自调用情况下会失效原因
  • Scrapy和Selenium结合使用完整步骤
  • C++系列之构造函数和析构函数
  • 龙迅#LT9711UX适用于双端口 MIPI DPHY/CPHY 转 DP1.4 产品应用,分辨率高达4K120HZ。
  • c++表达范围勿用数学符号
  • TCP-IP入门
  • 架构与通信机制:深入解析JMediaDataSource的JNI实现
  • 【每日学点鸿蒙知识】placement设置top、组件携带自定义参数、主动隐藏输入框、Web设置字体、对话框设置全屏宽
  • 静默模式下安装Weblogic 14.1.1.0.0
  • 医院大数据平台建设:基于快速流程化工具集的考察
  • Ashy的考研游记
  • u3d中JSON数据处理
  • 服务器部署LLM、Embedding
  • 罗德与施瓦茨ZN-Z51,8.5G网分校准件
  • 计算机网络 (12)物理层下面的传输媒体
  • C# 标准数字格式字符串
  • Pytorch使用手册-DCGAN 指南(专题十四)
  • Notepad++:下载安装及使用指南
  • C++通透讲解设计模式:开闭原则(1)
  • Python软体中使用 Kafka 实现高吞吐量的任务队列
  • 结合华为云实现人证核验
  • C++ 设计模式:抽象工厂(Abstract Factory)