返回执行结果的任务队列:ExecutorCompletionService

有时候我们需要展示一些内容,如果等所有内容都加载完毕再展示这样反而会降低用户体验; 因为如果消耗时间长那么用户需要瞪着空白的页面,反而会失去兴趣; 所以我们希望加载一点资源显示一点,对于那么超过我们容忍范围还未加载完毕的资源我们应该 不再去加载,放弃本次加载或者显示一些默认结果

模拟:

        final Random r = new Random();
		// 创建一个固定大小的线程池
		ExecutorService es = Executors.newFixedThreadPool(10);
		// 将所有处理结果提交到一个固定大小的队列(可不指定,默认创建一个无界队列)
		ExecutorCompletionService<String> ecs = new ExecutorCompletionService<String>(
				es,new LinkedBlockingQueue<Future<String>>(1000));
		for (int i = 0; i < 10; i++) {
			//提交所有任务
			ecs.submit(new Callable<String>() {
				@Override
				public String call() throws Exception {
					//模拟一个耗时操作
					long l = r.nextInt(4000);
					Thread.sleep(l);
					return Thread.currentThread().getName() + "|" + l;
				}
			});
			
			try {
				//获得返回结果,3s超时(表示我们能够容忍的最大等待时间)
				System.out.println(ecs.take().get(3, TimeUnit.SECONDS));
            } catch (InterruptedException e) {
            	// 线程被中断
            } catch (ExecutionException e) {
            	//
            	e.printStackTrace();
            } catch (TimeoutException e) {
            	// 超时,放弃这个结果
            }
			
		}
		es.shutdown();
pool-1-thread-1|884
pool-1-thread-2|3469
pool-1-thread-3|1001
pool-1-thread-4|927
pool-1-thread-5|3503
pool-1-thread-6|712
pool-1-thread-7|2015
pool-1-thread-8|2430
pool-1-thread-9|1613
pool-1-thread-10|2583

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏技术小讲堂

WCF中操作的分界于调用顺序和会话的释放操作分界实例停止

操作分界 在WCF操作契约的设计中,有时会有一些调用顺序的业务,有的操作不能最先调用,有的操作必须最后调用,比如在从一个箱子里拿出一件东西的时候,必须先要执行打...

34360
来自专栏有趣的django

35.Django2.0文档

第四章 模板  1.标签 (1)if/else {% if %} 标签检查(evaluate)一个变量,如果这个变量为真(即,变量存在,非空,不是布尔值假),系...

599100
来自专栏PHP实战技术

PHP经典面试题目汇总(上篇)

1、双引号和单引号的区别 双引号解释变量,单引号不解释变量 双引号里插入单引号,其中单引号里如果有变量的话,变量解释 双引号的变量名后面必须要有一个非数字、字母...

38470
来自专栏ChaMd5安全团队

PY交易之简单沙盒绕过

p猫表哥要我写一些有趣的东西,本人比较菜,见识也比较短浅,也不会ri站,更不会打ctf,只能随便说点我觉得还是比较好玩的东西。 ? 本人在大二上学期的时候自学了...

55470
来自专栏FreeBuf

Java反序列化漏洞从理解到实践

一、前言 在学习新事物时,我们需要不断提醒自己一点:纸上得来终觉浅,绝知此事要躬行。这也是为什么我们在学到知识后要付诸实践的原因所在。在本文中,我们会深入分析大...

337100
来自专栏FreeBuf

挖洞经验 | 命令注入突破长度限制

0x01 背景 很多时候,在我们历经千辛万苦挖掘出一个漏洞或者找到一个利用点的时候,却因为一些egg hurt的限制,导致get shell或者send pay...

263100
来自专栏分布式系统进阶

Kafka基础组件和辅助类库简介

19410
来自专栏Linyb极客之路

邂逅多线程

用多线程只有一个目的,那就是更好的利用cpu的资源,因为所有的多线程代码都可以用单线程来实现。说这个话其实只有一半对,因为反应“多角色”的程序代码,最起码每个角...

35780
来自专栏一枝花算不算浪漫

[Redis]Redis 概述及基本使用规范.

52980
来自专栏蓝天

redis的一些简介

Redis是Remote Dictionary Server的缩写,他本质上一个Key/Value数据库,与Memcached类似的NoSQL型数据库。

11910

扫码关注云+社区

领取腾讯云代金券