1.什么是JUC
JUC 是指java.util下的Java.util.concurrent、Java.util.concurren.atomic、Java.util.concurren.locks,是java多线程编程的基础
2.java实现多线程的方式
Java是运行在java虚拟机上,是没办法直接开启线程的,java无法直接操作硬件,通过调用本地方法start0()来开启线程。
(1)继承Thread类
(2)实现Runnable接口
(3)实现Callable接口
runnable:没有返回值且效率比callable相较低
3.进程和线程
进程:是系统进行资源分配和调度的基本单位,是程序的实体
线程:是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位
一个进程可以包含多个线程,线程并行的执行不同的任务,同一进程中的多条线程将共享该进程中的全部系统资源,
4.并发与并行的区别
并发:同一处理核心上有多个进程正在处理,但同一时间只能处理一个进程,进程交替执行
并行:多个处理核心上同一时间处理多个线程
并发编程是为了充分利用cpu的资源
5.线程的状态
NEW:创建
RUNNABLE:运行
BLOCKED:阻塞
WAITING:等待
TIMED_WAITING:超时等待
TERMINATED:终止
6.Synchronized 和 Lock 的区别
(1)Synchronized 内置的java关键字 Lock 是一个java类
(2)Synchronized 无法判断获取锁的状态,Lock 可以判断获取锁的状态
(3)Synchronized 会自动释放锁 Lock必须要手动释放锁
(4)Synchronized 如果获取到锁的线程进入阻塞,线程会一直等待下去,Lock不一定一直等待下去
(5)Synchronized 可重入锁,不可以中断,非公平 Lock 可重入锁,可以判断锁,非公平(可以自己设置)
(6)Synchronized 适合锁少量的代码同步问题 Lock 适合锁大量的代码同步问题
Synchronized 通过wait(),nofity(),nofityAll()通信来解决生产者和消费者之间的通讯问题
Lock通过与Condition()同步监视器配合来达到生产者和消费者之间的通讯问题