JUC
juc基础
1为什么多线程如此重要
- 摩尔定律失效,单核CPU主频提升缓慢,已经开始采用多核时代
- 高并发系统, 充分利用CPU,异步+回调 解决生产需求问题
2 进程线程是什么?
- 进程: 是程序的一次执行,是系统进行资源分配和调度的独立单位,每一个进程都有它自己的内存空间和系统资源
- 线程: 在同一个进程内又可以执行多个任务,而这每一个任务我们尽可以看做是一个线程,一个进程会有1个或多个线程的。
- 管程: Montor(监视器) 也就是我们平时所说的锁
3 用户线程和守护线程
java线程分为用户线程和守护线程 线程的daemon属性为true表示是守护线程,false表示是用户线程。 守护线程:是一种特殊的线程,在后台默默的完成一些系统性的服务,比如垃圾回收线程 用户线程:是系统的工作线程,它会完成这个程序需要完成的业务操作
4 Future和Callable接口
本地代码类 FutureTaskDemo
Future接口定义了操作异步任务执行一些方法,如获取异步任务的执行结果、取消任务的执行、判断任务是否被取消、判断任务执行是否完毕等。
Callable接口中定义了需要有返回的任务需要实现的方法。 比如主线程让一个子线程去执行任务,子线程可能比较耗时,启动子线程开始执行任务后, 主线程就去做其他事情了,过了一会才去获取子任务的执行结果。
FutureTask: 缺点,存在的问题 1 一旦调用get() 方法,不管是否计算完成都会导致阻塞。 也叫:不见不散 工作中要说用的话 ,也得用超时的api
System.out.println(futureTask.get());
工作中 不要阻塞,高并发 不要忘记了CAS,用轮训代替阻塞。 isDone() 轮训 轮询的方式会消耗无畏的CPU资源,而且也不见得能及时地得到计算结果, 如果想要一部获取结果,通常都会以轮训的方式去获取结果,尽量不要阻塞
想要完成一些复杂的任务: ·应对Future的完成时间,完成了可以告诉我,也就是我们的回调通知 ·将两个异步计算合成一个异步计算,这两个异步计算相互独立,同时第二个又依赖第一个的结果 ·当Future集合中某个任务最快结束时,返回结果 ·等待Future结合中的所有任务都完成
5 Future的改进 CompletableFuture
从 java8 开始引入了 CompletableFuture,他是Future的功能增强版,可以传入回调函数,当异步任务完成或者发生异常时候,自动调用对象的回调方法
CompletableFuture的优点: · 异步任务结束时,会自动回调某个对象的方法 · 异步任务出错时,会自动回调某个对象的方法 · 主线程设置好回调后,不在关心异步任务的执行,异步任务之间可以顺序执行
join和get的对比: join = get 一样的都会阻塞,区别就是join不抛出异常
1说说java锁事
悲观锁 与 乐观锁
|