线程私有变量

本文介绍了一种简单的方法来为每个线程分配唯一的编号并跟踪已创建的线程总数。通过一个具体的Java示例展示了如何实现这一功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

线程对象也是从一个(线程)类而构建的,线程类作为一个类也可以拥有自己的私有成员。这个成员为此线程对象私有,有时候使用线程私有变量,会巧妙避免一些并发安全的问题,提高程序的灵活性和编码的复杂度。

 

下面举例来说吧,统计一个线程类创建过多少个线程,并为每个线程进行编号。

 

package com.lavasoft.test; 


/** 

* 为线程添加编号,并确所创建过线程的数目 

* @author leizhimin 2010-1-4 14:15:31 

*/

 public class ThreadVarTest { 

        public static void main(String[] args) { 

                Thread t1 = new MyThread(); 

                Thread t2 = new MyThread(); 

                Thread t3 = new MyThread(); 

                Thread t4 = new MyThread(); 

                t1.start(); 

                t2.start(); 

                t3.start(); 

                t4.start(); 

        } 


class MyThread extends Thread { 

        private static int sn = 0;    //线程数 

        private int x = 0;                    //线程编号 


        MyThread() { 

                x = sn++; 

        } 


        @Override 

        public void run() { 

                Thread t = Thread.currentThread(); 

                System.out.println(t.getName() + "\t" + x); 

        } 

}

 

运行结果:

Thread-0  0 

Thread-1  1 

Thread-2  2 

Thread-3  3 


Process finished with exit code 0

 

这个程序是很多公司面试题,这是一种求解方式,应该是最简单的求解方式。还有用ThreadLocal实现的版本,还有其他的,都没有这个代码简洁。

线程私有变量是指在多线程环境中,每个线程拥有自己独立的变量副本,不同线程之间对该变量的操作互不影响。这种机制避免了多个线程共享同一变量时可能引发的并发问题,如数据竞争和一致性问题。 在 Java 中,`ThreadLocal` 是实现线程私有变量的一种典型方式。通过 `ThreadLocal`,每个线程都可以独立保存、访问自己的变量实例,而不会与其他线程变量发生冲突。其核心原理是:每个 `Thread` 对象内部维护了一个 `ThreadLocalMap` 类型的成员变量 `threadLocals`,该映射表存储的是 `<ThreadLocal 实例, 变量值>` 的键值对[^1]。 具体来说,当调用 `ThreadLocal.set(value)` 或 `ThreadLocal.get()` 时,JVM 会通过 `Thread.currentThread()` 获取当前线程对象,然后从该线程对象中查或创建一个 `ThreadLocalMap`,进而将当前 `ThreadLocal` 实例作为键与对应的值进行存取操作[^2]。 这种方式使得即使多个线程使用相同的 `ThreadLocal` 实例,它们各自保存的值也是完全隔离的,从而实现了线程级别的“全局”变量管理。 ### 示例代码 以下是一个简单的 `ThreadLocal` 使用示例: ```java public class ThreadLocalExample { // 定义一个 ThreadLocal 变量 private static ThreadLocal<Integer> threadLocalValue = ThreadLocal.withInitial(() -> 0); public static void main(String[] args) { Runnable task = () -> { // 每个线程设置自己的值 threadLocalValue.set((int) (Math.random() * 100)); System.out.println(Thread.currentThread().getName() + " 的值为: " + threadLocalValue.get()); }; // 创建并启动多个线程 new Thread(task).start(); new Thread(task).start(); new Thread(task).start(); } } ``` 在这个例子中,每个线程都会设置并读取属于自己的 `Integer` 值,彼此之间互不干扰。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值