IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> Callable多线程优化遍历查询 -> 正文阅读

[网络协议]Callable多线程优化遍历查询

????????刚接手一个项目,收到很多用户反馈某列表搜索太慢,每次点击【查询】需要3s多,看了下代码逻辑,大概是该项目只有主键id数据,但是列表需要展示id对应的所有全部数据,所以需要先查询出id列表,然后根据id列表遍历调用dubbo接口来获取数据进行整合,返回给前端;一个id调用dubbo接口的耗时大概150ms,最优情况下搜索只有1条数据,那么接口耗时150ms,但是如果是模糊搜索20条数据,则遍历查询耗时就需要3s多,而且查看链路统计,超过50%的请求都是模糊搜索,所以大部分用户搜索列表都是好使3s,所以肯定要优化一下;

方案两个:

1. 合作方提供一个dubbo接口,参数为List<int> id,调用一次完善所有数据,但是合作方推脱不给做,只能自己想办法;
2. 使用Callable多线程优化for循环调用dubbo接口;

Callable这里不做介绍了,大家有兴趣可以搜一下,它相对其他多线程操作有两个特点:

1. 可以获取线程执行结果;

2. 可以抛出线程中的异常

直接贴代码参考下:

1. 创建CallableTask类实现Callable接口

import java.util.concurrent.Callable;

/**
 * Callable任务类
 * 实现Callable接口,并实现call方法
 */
@Data
@NoArgsConstructor
@AllArgsConstructor
public class CallableTask implements Callable<String> {

    /**
     * 定义成员变量,接收参数
     */
    private String s;

    @Override
    public String call() throws Exception {
        //模拟调用dubbo接口
        Thread.sleep(1000);
        return s;
    }
}

2. 线程池中提交CallableTask

public void testCallable() throws InterruptedException, ExecutionException {
    //定义列表,元素10个
    List<String> list = Lists.newArrayList("a","b","c","d","e","f","g","h","i","j");

    //正常单线程逻辑
    StringBuilder sb = new StringBuilder();
    Long start = System.currentTimeMillis();
    for (String s : list) {
        //模拟调用dubbo接口
        Thread.sleep(1000);
        sb.append(s);
    }
    System.out.println(sb + "====>单线程逻辑===>cast:" + (System.currentTimeMillis() - start));


    //使用Callable多线程逻辑
    Long start1 = System.currentTimeMillis();
    List<Future> futureList = new ArrayList<>();
    //这里注意,一定要先收集future列表,再遍历future的get方法,因为get方法是阻断的,如果在for循环中get方法,那么和单线程没有任何区别
    for (String s : list) {
        //获取future,在最后用来获取线程执行结果
        Future<String> future = executorService.submit(new CallableTask(s));
        futureList.add(future);
    }
    StringBuilder sb1 = new StringBuilder();
    for (Future future : futureList) {
        //获取线程结果
        sb1.append(future.get());
    }
    System.out.println(sb + "====>callable多线程====>cast:" + (System.currentTimeMillis() - start1));
}

3. 执行结果?

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2022-03-10 22:59:52  更:2022-03-10 23:01:55 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/4 19:03:12-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码