账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    关于线程池的线程复用问题
    50
    0

    在这篇博客中https://www.cnblogs.com/sweet...
    看到以下观点

    package thread.base.threadloacl;
    
    import java.util.concurrent.ExecutorService;
    import java.util.concurrent.Executors;
    import java.util.concurrent.TimeUnit;
    
    /**
     * 
     * @author ZhenWeiLai
     *
     */
    public class B {
        static final InheritableThreadLocal<String> threadParam = new InheritableThreadLocal<>();
    
        public static void main(String[] args) throws InterruptedException {
            //固定池内只有存活3个线程
            ExecutorService execService = Executors.newFixedThreadPool(3);
            //死循环几次才能看出效果
            while (true) {
                //线程1,里面有两个子线程
                Thread t = new Thread(()->{
                        threadParam.set("abc");
                        System.out.println("t1:" + threadParam.get());
                        Thread t2 = new Thread(()->{
                            System.out.println("t2:" + threadParam.get());
    //                        threadParam.remove();
                        });
                        execService.execute(t2);
                        
                        Thread t3 = new Thread(()->{
                            System.out.println("t3:" + threadParam.get());
    //                        threadParam.remove();
                    });
                        execService.execute(t3);
                        
                });
                execService.execute(t);
                TimeUnit.SECONDS.sleep(1);
                //线程4,线程1同级
                Thread t4 = new Thread(()-> {
                    threadParam.set("CBA");
                        System.out.println("t4:" + threadParam.get());
                });
                execService.execute(t4);
            }
        }
    }
    t1:abc
    t2:abc
    t3:abc
    t4:CBA
    t1:abc
    t2:abc
    t3:abc
    t4:CBA
    t1:abc
    t2:abc
    t3:CBA //因复用线程而导致问题
    t4:CBA

    我想请问,线程复用导致t3输出CBA是怎么样的一个过程?
    Ps:在jdk8下已经复现此问题。

    2018年1月18日15:04:32 问题补充:
    我使用UnSafestaticFieldOffset获取对象的内存地址,四个线程内部分别执行,地址是一致的。
    或许是staticFieldOffset这个方法并不是获取内存地址的?

    try {
        Field threadParamF = ThreadPool_1.class.getDeclaredField("threadParam");
        System.out.println("t1 threadParam location:" + unsafe.staticFieldOffset(threadParamF));
    } catch (NoSuchFieldException e) {
        e.printStackTrace();
    }
    0
    打赏
    收藏
    点击回答
        全部回答
    • 0
    更多回答
    扫一扫访问手机版

    回答动态

    师傅被妖怪抓走了:发布了悬赏问题火爆全网的“元宇宙”到底是什么?预计能赚取 1积分收益
    酒后略带风情:发布了悬赏问题Android内存中Graphics与Code占用过高预计能赚取 10积分收益
    扛起拖把扫天下:发布了悬赏问题typescript如何导出接口配置?求解,谢谢!预计能赚取 10积分收益
    发布了悬赏问题Vue 如何改变返回页面的路径?如让B页面只能返回到A页面.预计能赚取 11积分收益
    发布了悬赏问题vue H5移动端;底部bottom固定定位,安卓弹起键盘导致页面变形如何解决?预计能赚取 10积分收益
    发布了悬赏问题请问为什么tomcat8.5 GET请求中文正常,POST请求还需要设置UTF-8.预计能赚取 10积分收益
    发布了悬赏问题vue2.5+ts创建以及引入jq的方法预计能赚取 11积分收益
    情场浪女:发布了悬赏问题import ggplot时报错module 'pandas' has no attribute 'tslib'预计能赚取 10积分收益
    见心书画许老师18753375161:发布了悬赏问题echarts3 legend禁止点击事件,允许悬浮事件预计能赚取 11积分收益
    aa_92cb0bd09f:发布了悬赏问题codewar上的一个问题预计能赚取 11积分收益