数据传输
常用的在层于层之间传输数据的方式有两种,一种是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对象.