您的位置:首页 > 编程语言 > Java开发

Java高并发 一 [几个重要概念]

2017-10-18 16:16 169 查看

Java高并发 一

1、关于高并发的几个重要概念

1.1 同步和异步

同步(Sync):就是在发出一个调用请求时,在没有得到结果响应之前,该调用不返回,也就是说必须一件一件事做,等前一件做完了才能做下一件事。

异步(Async):概念与同步相对,在发起一个调用请求之后,调用者在没有得到结果之前,可以继续执行后续任务。当这个调用完成后,一般通过状态、通知和回调来通知调用者。对于异步调用,调用的返回并不受调用者控制。

1.2 并发和并行



并发和并行在外在表象来说,是差不多的。由图所示,并行则是两个任务同时进行,而并发呢,则是一会做一个任务一会又切换做另一个任务。所以单个cpu是不能做并行的,只能是并发。

1.3 阻塞和非阻塞

阻塞和非阻塞关注的是程序在等待调用结果(消息,返回值)时的状态。

阻塞:是指调用结果返回之前,当前线程会被挂起。调用线程只有在得到结果之后才会返回。

非阻塞:指在不能立刻得到结果之前,该调用不会阻塞当前线程。

1.4 可见性、原子性、有序性

可见性:指当多个线程访问同一个变量时,一个线程改表了这个变量的值,其他线程能够看到修改后的值。Java提供了validate关键字来保证可见性。

原子性:即一个操作或者多个操作 要么全部执行并且执行的过程不会被任何因素打断,要么就都不执行。

有序性:即程序执行的顺序按照代码的先后顺序执行。

Reference:

1. https://my.oschina.net/hosee/blog/597934
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java 并发