同步调用是刚性调用,是阻塞式操作,必须等待调用方法体执行结束。
而异步调用是柔性调用,是非阻塞操作,在执行过程中,如调用其他方法,自己可以继续执行而不被阻塞等待方法调用完毕。
异步调用通常用在某些耗时长的操作上,这个耗时方法的返回结果,可以使用某种机制反向通知,或者再开启一个线程轮询。
反向通知方式需要异步系统和各个调用它的系统进行耦合;而轮询对于没有执行完的任务会不断地请求,从而加大执行机器的压力。
异步处理的任务是非时间敏感的。(非实时)比如,在连接池中,异步任务会定时回收空闲线程。举个现实中的例子,在代码管理平台中,提交代码的操作是同步调用,需要实时返回给用户结果。但是当前库的代码相关活动记录不是时间敏感的,在提交代码时,发送一个消息到后台的缓存队列中,后台服务器定时消费这些消息即可。
某些框架提供了丰富的异步处理方式,或者是把同步任务拆解成多个异步任务等。
同步与异步
最新推荐文章于 2023-04-17 17:58:27 发布