Java并发中的一些概念

并发和并行

并发和并行这两个概念经常被大家所混淆。并发是指多个任务交替的进行,并行是指多个任务同时进行。所以单核CPU只能实现并发,不能实现并行。

同步和异步

同步是指任务的执行,必须完全结束才能继续执行后续任务。异步是指任务开始执行后,将任务放在另外一个线程中执行,本线程直接就可以继续执行后续任务。比如一个人拿着水杯去饮水机那里接水,如果接水的过程中持续等待水接满,再回去翻邮件,这就是同步;如果再接水的过程中掏出手机,边接水边翻阅手机有相中的邮件便是异步。

阻塞和非阻塞

当线程由于IO操作或资源抢占失败等原因导致放弃CPU时间片,暂停线程执行的现象叫做阻塞。非阻塞与之相反。

死锁

死锁就是线程所需要的资源因为某种原因永远不能获取,导致线程永久阻塞的现象。例如:现在有一只碗和一双筷子,A和B两个人都需要吃饭,这时A拿到了碗,B拿到了筷子。A想要拿到筷子开始吃饭,B想要拿到碗开始吃饭,谁也不让着谁,这时两人会一直僵持下去,这种现象就是死锁,当然死锁不局限于两方对资源的抢占。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值