JUC正确姿势

JUC

juc基础

1为什么多线程如此重要
  • 摩尔定律失效,单核CPU主频提升缓慢,已经开始采用多核时代
  • 高并发系统, 充分利用CPU,异步+回调 解决生产需求问题
2 进程线程是什么?
  • 进程: 是程序的一次执行,是系统进行资源分配和调度的独立单位,每一个进程都有它自己的内存空间和系统资源
  • 线程: 在同一个进程内又可以执行多个任务,而这每一个任务我们尽可以看做是一个线程,一个进程会有1个或多个线程的。
  • 管程: Montor(监视器) 也就是我们平时所说的锁
    在这里插入图片描述
    在这里插入图片描述
3 用户线程和守护线程

java线程分为用户线程和守护线程
线程的daemon属性为true表示是守护线程,false表示是用户线程。
守护线程:是一种特殊的线程,在后台默默的完成一些系统性的服务,比如垃圾回收线程
用户线程:是系统的工作线程,它会完成这个程序需要完成的业务操作
在这里插入图片描述

4 Future和Callable接口

本地代码类 FutureTaskDemo

Future接口定义了操作异步任务执行一些方法,如获取异步任务的执行结果、取消任务的执行、判断任务是否被取消、判断任务执行是否完毕等。

Callable接口中定义了需要有返回的任务需要实现的方法。
比如主线程让一个子线程去执行任务,子线程可能比较耗时,启动子线程开始执行任务后,
主线程就去做其他事情了,过了一会才去获取子任务的执行结果。

FutureTask: 缺点,存在的问题
1 一旦调用get() 方法,不管是否计算完成都会导致阻塞。 也叫:不见不散
工作中要说用的话 ,也得用超时的api

        //不见不散,只要出现get方法,不管是否计算完成都阻塞等待结果出来再运行
        System.out.println(futureTask.get());
        //过时不候
        //System.out.println(futureTask.get(2L,TimeUnit.SECONDS));

工作中 不要阻塞,高并发 不要忘记了CAS,用轮训代替阻塞。
isDone() 轮训 轮询的方式会消耗无畏的CPU资源,而且也不见得能及时地得到计算结果,
如果想要一部获取结果,通常都会以轮训的方式去获取结果,尽量不要阻塞

想要完成一些复杂的任务:
·应对Future的完成时间,完成了可以告诉我,也就是我们的回调通知
·将两个异步计算合成一个异步计算,这两个异步计算相互独立,同时第二个又依赖第一个的结果
·当Future集合中某个任务最快结束时,返回结果
·等待Future结合中的所有任务都完成

5 Future的改进 CompletableFuture

在这里插入图片描述
在这里插入图片描述
从 java8 开始引入了 CompletableFuture,他是Future的功能增强版,可以传入回调函数,当异步任务完成或者发生异常时候,自动调用对象的回调方法

CompletableFuture的优点:
· 异步任务结束时,会自动回调某个对象的方法
· 异步任务出错时,会自动回调某个对象的方法
· 主线程设置好回调后,不在关心异步任务的执行,异步任务之间可以顺序执行

join和get的对比:
join = get 一样的都会阻塞,区别就是join不抛出异常

1说说java锁事

1悲观锁 与 乐观锁
2公平锁与非公平锁

你为什么平时都用非公平锁?
非公平锁缺点之一:容易出现锁饥饿现象

3 可重入锁又名递归锁
4 死锁
5 线程中断机制
6 LockSupport
7 JMM
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值