同步、异步、阻塞和非阻塞之间的区别

同步和异步,阻塞和非阻塞是大家经常会听到的概念,但是它们是从不同维度来描述一件事情,常常很容易混为一谈。1. 同步和异步同步和异步描述的是消息通信的机制。同步当一个request发送出去以后,会得到一个response,这整个过程就是一个同步调用的过程。哪怕response为空,或者response的返回特别快,但是针对这一次请求而言就是一个同步的调用。异步当一个request发送出去以后,没有得到想要的response,而是通过后面的callback、状态或者通知的方式获得结果。可以这么理解,
摘要由CSDN通过智能技术生成

同步和异步,阻塞和非阻塞是大家经常会听到的概念,但是它们是从不同维度来描述一件事情,常常很容易混为一谈。

1. 同步和异步

同步和异步描述的是消息通信的机制。

同步
当一个request发送出去以后,会得到一个response,这整个过程就是一个同步调用的过程。哪怕response为空,或者response的返回特别快,但是针对这一次请求而言就是一个同步的调用。

异步
当一个request发送出去以后,没有得到想要的response,而是通过后面的callback、状态或者通知的方式获得结果。可以这么理解,对于异步请求分两步:1)调用方发送request没有返回对应的response(可能是一个空的response);2)服务提供方将response处理完成以后通过callback的方式通知调用方。对于1)而言是同步操作(调用方请求服务方),对于2)而言也是同步操作(服务方回掉调用方)。从请求的目的(调用方发送一个request,希望获得对应的response)来看,这两个步骤拆分开来没有任何意义,需要结合起来看,而这整个过程就是一次异步请求。异步请求有一个最典型的特点:需要callback、状态或者通知的方式来告知调用方结果。

2. 阻塞和非阻塞

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

阻塞
阻塞调用是指调用方发出request的线程因为某种原因࿰

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中的同步和异步、阻塞阻塞是常用的并发和网络编程概念。 同步和异步涉及到代码的执行方式。同步指的是任务按照顺序执行,一个任务完成后才能执行下一个任务;而异步是指任务可以并发执行,不需要等待前一个任务完成。 阻塞阻塞涉及到线程的等待状态。阻塞是指一个线程在执行某个操作时,如果这个操作没有完成,那么线程就会一直等待,不能执行其他操作;而阻塞是指一个线程在执行某个操作时,执行该操作不会等待,可以立即执行其他操作。 在Java中,同步通常是通过synchronized关键字来实现的。同步可以确保多个线程按照指定的顺序访问共享资源,避免出现竞态条件。异步则可以通过线程池、Future、CompletableFuture等机制实现,可以提高程序的并发处理能力。 阻塞是指线程在执行某个操作时,如果该操作没有完成,线程会进入等待状态,不能执行其他操作。在Java中,阻塞通常发生在I/O操作上,如读写文件、网络通信等。阻塞则是指线程执行某个操作时不会等待,而是立即返回结果,可以继续执行其他操作。在Java中,阻塞通常与NIO相关,使用Selector和Channel来实现阻塞的网络通信。 综上所述,同步和异步、阻塞阻塞是并发编程中重要的概念,它们分别从代码执行方式和线程等待状态的角度来描述程序的行为。在Java中,同步和异步通常通过synchronized关键字和线程池等机制来实现,而阻塞阻塞通常与I/O操作和NIO相关。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值