概念区分
-
并发与并行
并发:指两个或多个事件在同一时间段内发生
并行:指两个或多个事件在同一时刻发生(同时发生) -
线程与进程
进程:一个内存中运行的应用程序,是程序的一次执行,系统运行一个程序即是进程从创建、运行到消亡的过程。
线程:进程中的一个执行单元,负责当前进程中程序的执行。一个进程中可以有多个线程。 -
单线程与多线程
当多个单线程之间出现程序错误时,后续单线程无法继续执行
多个线程之间互不影响(在不同的栈空间) -
死锁
两个或两个以上的线程在执行过程中,因争夺资源而造成的互相等待的现象,在无外力作用的情况下,这些线程会一直相互等待而无法继续运行下去。
发生死锁的必要条件:互斥、请求并保持、不可剥夺、环路等待
创建方式
- 实现Runnable接口的run方法
- 继承Thread类并重写run方法
- 使用FutrueTask方式
常用方法
-
wait()
当一个线程调用一个共享变量的wait()方法时,该调用线程会被阻塞挂起。直到其他线程调用了该共享对象的notify()或者notifyAll()方法;或者其他线程调用了该线程的interrupt()方法(中断线程)抛出异常后才返回。
注意,当前线程调用共享变量的wait()方法后只会释放当前共享变量上的锁,如果当前线程还持有其他共享变量的锁,则这些锁是不会被释放的。