Java高并发 一
1、关于高并发的几个重要概念
1.1 同步和异步
同步(Sync):就是在发出一个调用请求时,在没有得到结果响应之前,该调用不返回,也就是说必须一件一件事做,等前一件做完了才能做下一件事。
异步(Async):概念与同步相对,在发起一个调用请求之后,调用者在没有得到结果之前,可以继续执行后续任务。当这个调用完成后,一般通过状态、通知和回调来通知调用者。对于异步调用,调用的返回并不受调用者控制。
1.2 并发和并行
并发和并行在外在表象来说,是差不多的。由图所示,并行则是两个任务同时进行,而并发呢,则是一会做一个任务一会又切换做另一个任务。所以单个cpu是不能做并行的,只能是并发。
1.3 阻塞和非阻塞
阻塞和非阻塞关注的是程序在等待调用结果(消息,返回值)时的状态。
阻塞:是指调用结果返回之前,当前线程会被挂起。调用线程只有在得到结果之后才会返回。
非阻塞:指在不能立刻得到结果之前,该调用不会阻塞当前线程。
1.4 可见性、原子性、有序性
可见性:指当多个线程访问同一个变量时,一个线程改表了这个变量的值,其他线程能够看到修改后的值。Java提供了validate关键字来保证可见性。
原子性:即一个操作或者多个操作 要么全部执行并且执行的过程不会被任何因素打断,要么就都不执行。
有序性:即程序执行的顺序按照代码的先后顺序执行。
Reference:
1. https://my.oschina.net/hosee/blog/597934