1、什么是JUC
JUC就是java.util.concurrent工具包的简称。这是一个处理线程的工具包,JDK1.5开始出现的。
2. 线程基础知识
进程是指运行中的应用程序,是操作系统进行资源(CPU,内存空间,磁盘IO)分配的最小单位。用户每启动一个进程,操作系统就会为该进程分配一个独立的地址空间(内存空间)目前操作系统支持多进程多任务 eg:QQ.exe
2.1.1 特点
-
独立性:不同的进程之间是独立的,相互之间资源不共享
-
动态性:进行在系统中不是静止不动的,而是在系统中一直活动的
-
并发性:多个进程可以在单个处理器上同时进行且互补影响
2.2 线程
线程是进程的一个实体,是CPU调度和分配的基本单位,它是比进程更小的,能独立运行的基本单位,是进程的组成部分,一个进程可以有多个线程,线程共享进程所拥有的全部资源,每个线程去处理一个特定的子任务,必须依赖于进程而存在。
多线程实际上是交替占用CPU资源,而非我们表面看起来的并行执行。main方法是单线程
2.2.1 特点
-
线程的执行是抢占式的
-
多个线程在同一个进程中可以并发执行(CUP快速的在不同线程之间切换,CPU时间片轮转机制)
-
当前运行的线程在任何时候都有可能被挂起,以便另外一个线程可以运行
2.2.2 优点
-
充分利用CPU的资源
-
加快响应用户的时间
-
可以使你的代码模块化,异步化,简单化
2.2.3 进程和线程的关系以及区别
-
一个程序运行后至少有一个进程
-
一个进程可以包含多个线程,但是至少需要有一个线程,否则这个进程是没有意义的
-
进程间不能共享资源,但线程之间可以
-
系统创建进程需要为该进程重新分配系统资源,而创建线程则容易的多,因此使用线程实现多任务并发比多进程的效率高
2.2.4 线程的状态
线程有6中状态,Java不能创建线程
public enum State { // java能够创建线程吗? 不能! // 新建 NEW, // 运行 RUNNABLE, // 阻塞 BLOCKED, // 等待 WAITING, // 延时等待 TIMED_WAITING, // 终止! TERMINATED; }
2.3 并发、并行
2.3.1 并发
多个线程操作同一个资源,交替执行的过程
2.3.2 并行
多个线程同时执行,只有在多核CPU下才能完成!
我们使用多线程或者并发编程的目的:提高效率,让CPU一直工作,达到最高处理性能。
2.4 wait和sleep区别
-
类不同:wait: Object类 sleep Thread类
-
会不会释放资源:sleep:抱着锁睡觉,不会释放锁! wait会释放锁
-
使用范围不同:
wait和notify是一组,一般用在线程通信的时候 sleep就是一个单独的方法,在那里都可以用! 在JUC编程中,线程休眠怎么实现 Thread.Sleep //时间单位 TimeUnit.SECONDS.sleep(3)
-
关于异常:sleep 需要捕获异常
Synchronized和Lock区别
-
Synchronized 是一个关键字 Lock是一个对象
-
Synchronized 无法尝试获取锁, Lock 可以尝试获取锁,判断;
-
Synchronized 会自动释放锁(a线程执行完毕,b如果异常了,也会释放锁) Lock锁是手动释放锁,如果你不释放锁就会死锁
-
Synchronized (线程A(获得锁,如果阻塞),线程B(等待,一直等待);)lock,可以尝试获取锁,失败了之后就放弃
-
Synchronized一定是非公平的,但是Lock锁可以是公平的,通过参数设置
-
代码量特别大的时候,我们一般使用Lock实现精准控制,Synchronized 适合代码量比较小的同步问题