ThreadLocal 简单理解

package com.qimh.test;

public class ThreadLocalDemo {

	
	ThreadLocal<Long> longLocal = new ThreadLocal<Long>();
    ThreadLocal<String> stringLocal = new ThreadLocal<String>();
    ThreadLocal<Long> startTime = new ThreadLocal<Long>();
    ThreadLocal<Long> endTime = new ThreadLocal<Long>();
    
    //普通变量值,会被修改
    //String str = "";
    ThreadLocal<String> str = new ThreadLocal<String>();
 
     
    public void set() {
        longLocal.set(Thread.currentThread().getId());
        stringLocal.set(Thread.currentThread().getName());
        startTime.set(System.currentTimeMillis());
        //str = Thread.currentThread().getName();
        str.set(Thread.currentThread().getName());
    }
     
    public long getLong() {
        return longLocal.get();
    }
     
    public String getString() {
        return stringLocal.get();
    }
    
    public long getStartTime(){
    	
    	return startTime.get();
    }
     
    public static void main(String[] args) throws InterruptedException {
        final ThreadLocalDemo test = new ThreadLocalDemo();
         
         
        test.set();
        System.out.println(test.getLong());
        System.out.println(test.getString());
        System.out.println(test.getStartTime());
        System.out.println("str:" +test.str);
     
         
        Thread thread1 = new Thread(){
            public void run() {
                test.set();
                System.out.println(test.getLong());
                System.out.println(test.getString());
                System.out.println(test.getStartTime());
                System.out.println((System.currentTimeMillis() - test.getStartTime() + "ms"));
                try {
					sleep(1000);
				} catch (InterruptedException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
            };
        };
        thread1.start();
        thread1.join();
         
        System.out.println(test.getLong());
        System.out.println(test.getString());
        System.out.println((System.currentTimeMillis() - test.getStartTime() + "ms"));
        System.out.println("str:" +test.str);
    }
}

参考链接:https://www.cnblogs.com/dolphin0520/p/3920407.html

转载于:https://my.oschina.net/qimhkaiyuan/blog/2991270

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值