一、JUC介绍
1、JUC的简述
在 Java 5.0 提供了 java.util.concurrent (简称JUC )包,在此包中增加了在并发编程中很常用的实用工具类,用于定义类似于线程的自定义子系统,包括线程池、异步 IO 和轻量级任务框架。提供可调的、灵活的线程池。还提供了设计用于多线程上下文中的 Collection 实现等!
2、进程与线程的区别
进程:是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。 在当代面向线程设计的计算机结构中,进程是线程的容器。程序是指令、数据及其组织形式的描述,进程是程序的实体。是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。程序是指令、数据及其组织形式的描述,进程是程序的实体。(说人话:进程就是在系统中正在运行的一个应用程序)
线程:是操作系统能够运行调度的最小单位,被包含在进程之中,并且进程可以包含多个线程。是进程中的一个单一顺序的控制流,一个进程中可以并发执行多个线程,每条线程可以执行不同的任务。
3、线程的状态
NEW(新建)
RUNNABLE,(准备就绪)
BLOCKED,(阻塞)
WAITING,(不见不散)
TIMED_WAITING,(过时不候)
TERMINATED;(终结)
4、wait/sleep的区别:
4.1、方法所属的类不同:
sleep是Thread的静态方法,而wait是Object的方法。
4.2、对锁的释放不同
sleep不会释放锁,也不需要占有锁。而wait会释放锁,但调用他的前提是当前线程占有锁。(代码在synchronized中)
4.3、中断方法相同
他们都可以被interrupted方法中断。
5、并发与并行
并发:同一时刻多个线程在访问同一个资源,多个线程对一个点。
并行:多项工作同时进行,然后在汇总。