并发和并行
并发和并行这两个概念经常被大家所混淆。并发是指多个任务交替的进行,并行是指多个任务同时进行。所以单核CPU只能实现并发,不能实现并行。
同步和异步
同步是指任务的执行,必须完全结束才能继续执行后续任务。异步是指任务开始执行后,将任务放在另外一个线程中执行,本线程直接就可以继续执行后续任务。比如一个人拿着水杯去饮水机那里接水,如果接水的过程中持续等待水接满,再回去翻邮件,这就是同步;如果再接水的过程中掏出手机,边接水边翻阅手机有相中的邮件便是异步。
阻塞和非阻塞
当线程由于IO操作或资源抢占失败等原因导致放弃CPU时间片,暂停线程执行的现象叫做阻塞。非阻塞与之相反。
死锁
死锁就是线程所需要的资源因为某种原因永远不能获取,导致线程永久阻塞的现象。例如:现在有一只碗和一双筷子,A和B两个人都需要吃饭,这时A拿到了碗,B拿到了筷子。A想要拿到筷子开始吃饭,B想要拿到碗开始吃饭,谁也不让着谁,这时两人会一直僵持下去,这种现象就是死锁,当然死锁不局限于两方对资源的抢占。