数据传输

常用的在层于层之间传输数据的方式有两种,一种是request域对象携带数据,另一种是ThreadLocal方式
request对象是我们常用的通过传入request域对象,从域中拿到数据.
所以本文主要说一下ThreadLocal方式.

ThreadLocal

利用request对象进行数据传输,需要一直在方法参数中进行传参httpservletrequest很麻烦.所以也就有了使用threadlocal方式.

介绍

1.名词解释: 本地线程变量
2.作用: 在多线程条件下使用ThreadLocal可以实现现场内数据的共享.
注意事项:
1).必须是同一线程
2).注意内存泄露的问题

API

简单的API使用

public class UserThreadLocal {

    //1.定义变量
    private static ThreadLocal<User> thread = new ThreadLocal<>();

    public static void set(User user){  //赋值
        thread.set(user);
    }

    public static User get(){           //取值

        return thread.get();
    }

    public static void remove(){        //移除
        thread.remove();
    }
    //移除一般是在拦截器的after方法中进行
}

问题

问: 在WEB前台拦截器中使用ThreadLocal进行数据传参,

1:WEB前台的Controller中能否获取数据---可以

2:业务后台的Service层中能否获取数据---不可以
因为:WEB前台服务器与业务后台的服务器的通讯是通过Dubbo框架的RPC实现的. RPC相当于开启了一个新的线程,所以无法通讯.

关于ThreadLocal总结

1.在同一个线程内可以使用ThreadLocal
2.“一般条件下” 在同一个tomcat内的线程为同一个线程.

若想在不同线程中获取数据就用request对象.

03-05 21:54