数据传输
常用的在层于层之间传输数据的方式有两种,一种是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对象.
ThreadLocal常用于在同一线程内共享数据,避免了频繁传递参数的麻烦。然而,在WEB应用中,由于RPC调用如Dubbo会在不同线程间通信,导致ThreadLocal无法跨线程传递数据。本文探讨了ThreadLocal在Controller和Service层的数据传输限制,并提醒注意内存泄露风险。在使用ThreadLocal时,确保理解其工作原理和适用场景。
3061

被折叠的 条评论
为什么被折叠?



