线程池以及子线层运用

/**
 * 线程池管理
 */
public class ThreadPoolManager {


private ThreadPoolManager() {
}

         //懒汉式 是加同步锁
// 饿汉式 线程安全
private static ThreadPoolManager instance = new ThreadPoolManager();
private PoolProxy longPoolProxy; //  给联网使用的线程池
private PoolProxy  shortPoolProxy; // 读写文件使用的线程池
public static ThreadPoolManager getInstance() {
return instance;
}


// 联网 
// 读写文件
// 效率最高 cpu 核心数 *2+1
// 1 *2+1
public PoolProxy createLongThreadPool() {
if (longPoolProxy == null) {
longPoolProxy = new PoolProxy(5, 5, 5000);
}
return longPoolProxy;
}


public PoolProxy createShortThreadPool() {
if (shortPoolProxy == null) {
shortPoolProxy = new PoolProxy(3, 3, 5000);
}
return shortPoolProxy;
}


/**
* 配置线程池 代理类 ThreadPoolExecutor 线程池

* @author wxj

*/
public class PoolProxy {
private int corePoolSize;
private int maximumPoolSize;
private long time;
private ThreadPoolExecutor threadPool; // 线程池


public PoolProxy(int corePoolSize, int maximumPoolSize, long time) {
super();
this.corePoolSize = corePoolSize;
this.maximumPoolSize = maximumPoolSize;
this.time = time;
}


@SuppressLint("NewApi")
public void execute(Runnable r) {
/**
* 1.corePoolSize 初始化线程数量 2.maximumPoolSize 出了初始化 线程数量 另外最多 能创建的线程数量
* 3.keepAliveTime 如果没有任务 最多的存活时间 4. TimeUnit时间单位
*/
if (threadPool == null) { // 当线程池 为空的时候才去创建
threadPool = new ThreadPoolExecutor(corePoolSize,
maximumPoolSize, time, TimeUnit.MILLISECONDS,
new LinkedBlockingDeque<Runnable>(10));
}
// 就直接执行任务
threadPool.execute(r);
}


public void cancel(Runnable r) {
// threadPool 不能为空 threadPool 没有崩溃 threadPool 没有停止
if (threadPool != null && !threadPool.isShutdown()
&& !threadPool.isTerminated()) {
threadPool.remove(r);
}
}
}

}


这里在线程池里做好对线层的处理然后就是调用   创建一个线层的工具类,

public class ThreadUtils {


/**
* 子线程执行  给联网 ... 特别耗时的 操作使用
* @param r
*/
public static void runOnBackThread(Runnable r){
// new Thread(r).start();
ThreadPoolManager.getInstance().createLongThreadPool().execute(r);
}
/**
* 子线程执行   给相对联网  耗时少的操作使用
* @param r
*/
public static void runOnShortBackThread(Runnable r){
// new Thread(r).start();
ThreadPoolManager.getInstance().createShortThreadPool().execute(r);
}

private static Handler handler = new Handler();
/**
* 在主线程执行
* @param r
*/
public static void runOnUiThread(Runnable r){
handler.post(r);
}
}


然后下一步就是在界面代码中哪里用到  就在哪里调用工具类的线层:

runOnBackThread ();   runOnShortBackThread(); runOnUiThread();



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个问题可能是因为FeignClient在调用时会新开一个线程,但是这个线程没有继承主线程的ThreadLocal变量,所以导致了Token丢失的问题。解决这个问题可以尝试在ThreadPoolExecutor的execute方法中,手动将主线程的ThreadLocal变量传递给线程,代码示例如下: ```java ThreadPoolExecutor executor = new ThreadPoolExecutor(corePoolSize, maximumPoolSize, keepAliveTime, unit, workQueue); executor.execute(() -> { // 在线程中调用FeignClient时,手动将主线程的ThreadLocal变量传递给线程 RequestContext context = RequestContext.getCurrentContext(); RequestAttributes requestAttributes = RequestContextHolder.currentRequestAttributes(); context.set("requestAttributes", requestAttributes); try { // 调用FeignClient // ... } finally { context.unset(); } }); ``` 在FeignClient中,可以通过RequestContextHolder获取ThreadLocal变量,示例如下: ```java @Component public class MyFeignClientInterceptor implements RequestInterceptor { @Override public void apply(RequestTemplate requestTemplate) { RequestContext context = RequestContext.getCurrentContext(); RequestAttributes requestAttributes = (RequestAttributes) context.get("requestAttributes"); ServletRequestAttributes attributes = (ServletRequestAttributes) requestAttributes; HttpServletRequest request = attributes.getRequest(); // 获取Token等信息 // ... // 将Token等信息添加到header中 requestTemplate.header("Authorization", token); } } ``` 这样就可以在线程中正确地获取到主线程中的ThreadLocal变量,避免了Token丢失的问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值