java多线程和高并发(4)

p12

Executor 线程池的最顶层接口,里面有一个execute方法需要实现,但是一般我们都不要自己去实现。
ExecutorService接口继承自Executor,不仅有execute方法,执行无返回值的runnable,自己还增加了方法如submit,此方法可以执行有返 回值的callable和没有返回值的runnable
Executors是一个操纵Executor的工具类

p13

TheadPool
java的所有线程池都实现了ExecutorService接口
executor会自动调用runnable的run方法

ExecutorService sercice=Executors.newFixedTheadPool(5);//有execute和submit的方法来执行任务
service.execute(........);//执行任务
service.shutdown();//关闭线程池
service.shutdownnow();//立即关闭线程池
FutureTask<Integer> task=new FutureTask<>(........);
new Thread(task).start();//将future任务放在线程中并启动起来
task.get();//获得返回值
p14

newFixedThreadPool指定线程的大小

ExecutorService sercice=Executors.newFixedTheadPool(5);//有execute和submit的方法来执行任务
Future<Integer> f=service.submit({...................reutrn 1;});
f.get();//获得返回值

使用线程池进行并行计算,例子是计算1到20000之间的素数

newCachedThreadPool来新的任务先看线程池中有无空闲线程,无的话就新启一个线程,线程默认存活时间时一分钟

p15

newSingleThreadExecutor创建的线程池中只会有一个线程,这个作用的就是一定是保证任务的顺序执行。
newScheduledThreadPool

ScheduledExecutorService service = Executors.newScheduledThreadPool(4);
//下面方法的意思是第一个任务立即执行,以后的任务隔500毫秒后执行,最多起四个线程,没有线程可用任务就等待
service.scheduleAtFixedRate({}//执行的任务
							,0//第一个任务执行前的等待时间
							,500//相邻任务间的等待时间
							,TimeUnit.MILLTSECONDS)

newWorkStealingPool每个线程维护一个自己的队列,当一个线程维护的队列里没有任务它可以去偷别的线程任务队列里的任务。这个线程池中运行的任务都是deamon的精灵线程(守护线程,后台线程)。这个线程池使用的是由ForkJoinPool实现的

p16

ForkJionPool
执行的任务一般都是继承自ForkJoinTask的子类RecursiveAction(无返回值)和RecursiveTask(有返回值)。其中的fork方法进行分叉,join方法进行打印

大部分的线程池背后都是使用的ThreadPoolExecutor实现的

p17

parallelStream是java8的东西,运用了多线程

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值