基础概念
1、并发:两个或多个事件在同一时间段内发生。“同时”
2、并行:两个或多个事件在同一时刻内发生。 同时
3、进程:正在运行的程序的实例。一个进程包含多个线程。
4、线程:包含在进程之中,是进程中的实际运作单位。一个进程可以并发多个线程,每条线程并发执行不同的任务。
5、通信:线程之间以何种机制来交换信息。
6、同步:发送一个请求,需要等待返回,才能够发送下一个请求。
7、异步:发送一个请求,不需要等待返回,随时可以发送下一个请求。
例子:
并发和并行:
- 吃饭吃到一半,电话来了,直到吃完再去接电话,这就说明并发和并行都不支持。
- 吃饭吃到一半,电话来了,停了下来接电话,接完电话继续吃饭,这就说明支持并发。(看上去像是“同时”执行)
- 吃饭吃到一半,电话来了,一边打电话一边吃饭,这就说明支持并行。(真正的同时进行)
参考:https://blog.csdn.net/weixin_30363263/article/details/80732156
多线程和单线程:
- 早上上班,正要打卡的时候,手机响了,先接电话,再打卡,这就说明支持单线程。
- 早上上班,正要打卡的时候,手机响了,一边打卡一边接电话,这就说明支持多线程。
参考:https://blog.csdn.net/u012134199/article/details/46290465
同步和异步:
- 同步:A线程要请求某个资源,但是此资源正在被B线程使用中,因为同步机制存在,A线程请求不到,怎么办,A线程只能等待下去。
- 异步:A线程要请求某个资源,但是此资源正在被B线程使用中,因为没有同步机制存在,A线程仍然请求的到,A线程无需等待。
区别
并发和并行:
- 并发:不是真正意义上的“同时”。
- 并行:真正的同时。
单线程和多线程:
- 单线程:只能顺序执行,无法并发执行。效率低
- 多线程:拥有多个线程,每个线程都是独立的单元,执行互不影响,可以并发执行。效率高
同步和异步:Java中的交互方式
- 同步:需要进行等待
- 异步:不需要进行等待(优先使用)