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

Java高并发 一

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

1.1 同步和异步

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

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

1.2 并发和并行

并发和并行

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

1.3 阻塞和非阻塞

阻塞和非阻塞关注的是程序在等待调用结果(消息,返回值)时的状态。
阻塞:是指调用结果返回之前,当前线程会被挂起。调用线程只有在得到结果之后才会返回。
非阻塞:指在不能立刻得到结果之前,该调用不会阻塞当前线程。

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

可见性:指当多个线程访问同一个变量时,一个线程改表了这个变量的值,其他线程能够看到修改后的值。Java提供了validate关键字来保证可见性。
原子性:即一个操作或者多个操作 要么全部执行并且执行的过程不会被任何因素打断,要么就都不执行。
有序性:即程序执行的顺序按照代码的先后顺序执行。

Reference:
1. https://my.oschina.net/hosee/blog/597934

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值