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
相关文章推荐
- 虚拟机中的几个重要概念
- 介绍J2ME平台的几个重要概念
- IntelliJ IDEA 项目相关的几个重要概念介绍
- 机器学习几个重要概念的区别
- cocos2d-x的几个重要概念
- Git开发实战(二)之Git的几个重要位置的概念
- 并发编程的几个基本概念
- 关于AJAX的几个重要概念
- 仿基因编程原理导论(里面的几个重要的概念正在做修正,所以这只能算是一个原理的初稿。)
- iphone开发中,委托、代理、协议、数据源等几个重要概念
- 介绍J2ME编程中的几个重要概念
- Maven中的几个重要概念(二):lifecycle, phase and goal
- oracle数据库的几个重要概念
- 14.IntelliJ IDEA 项目相关的几个重要概念介绍 - IntelliJ IDEA 使用教程
- SIP协议入门:初学者必须明白的几个重要概念
- Mac OS开发中,委托、代理、协议、数据源等几个重要概念
- 仿基因编程原理导论(里面的几个重要的概念正在做修正,所以这只能算是一个原理的初稿。)
- OpenStreetMap初探(三)——几个重要概念
- Java高并发程序设计笔记1之重要概念
- 邹晓辉围绕“语言、信息、知识和智慧”几个重要概念展开的长期研究 及其新近成果乃至国内外推广普及的尝试进展