java 多线程(threadlocal)

本文通过一个具体的Java示例,深入浅出地介绍了ThreadLocal的工作原理及其在多线程环境下的应用。展示了如何利用ThreadLocal为每个线程提供独立的变量副本,避免了线程间的数据竞争。
package com.fredric.demo;

import java.util.Random;

public class App {

public static class MyRunnable1 implements Runnable {
//ThreadLocal是一个线程局部变量
private ThreadLocal<String> threadlocal
= new ThreadLocal<String>();

private int tmp;

public void run() {
//threadlocal 包含方法:
//set:创建一个线程本地变量
//remove:移除该本地变量
//get:获取该本地变量的值
//在hibernate中被用于本地session管理
threadlocal.set("Name:"+new Random().nextInt(10));
int i = new Random().nextInt(10);

System.out.println("set tmp: " + i);

tmp = i;
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName() + " : " + threadlocal.get() + " " + tmp);
}
}

public static void main(String[] args) {
MyRunnable1 r = new MyRunnable1();
Thread t1 = new Thread(r,"thread1");
Thread t2 = new Thread(r,"thread2");
t1.start();
t2.start();

/*
输出如下:局部变量没有改变,而Threadlocal每个线程有自己独立的副本
set tmp: 0
set tmp: 1
thread1 : Name:3 1
thread2 : Name:4 1 */
}
}

转载于:https://www.cnblogs.com/Fredric-2013/p/4568937.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值