同步、异步、阻塞、非阻塞、回调函数

同步:
执行一个操作之后,等待结果,然后才继续执行后续的操作。
异步:
执行一个操作后,可以去执行其他的操作,然后等待通知再回来执行刚才没执行完的操作。
阻塞:
进程给CPU传达一个任务之后,一直等待CPU处理完成,然后才执行后面的操作。
非阻塞:
非阻塞就是将阻塞的等候时间区块细分成若干个小的阻塞时间块,在若干个阻塞之间,CPU有机会处理其他进程的任务。
进程给CPU传达任务后,继续处理后续的操作,隔断时间再来询问之前的操作是否完成。这样的过程其实也叫轮询。
回调函数:
方法A需要方法B的结果作为函数的参数
方法A被作为参数传给方法B
在方法B获取方法A所需的参数,并调用方法A传入参数后
方法A开始执行

回调函数:
    1.回调可以是同步也可以是异步
    2.同步可以是单线程也可以是多线程
    3.异步必须是多线程或多进程
    4.javascript 是单线程语言
    5.node与java是多线程语言
    
同步回调:
    把函数b传递给函数a。执行a的时候,回调了b,a要一直等到b执行完才能继续执行;
    同一线程的阻塞等候,等b执行完毕,a可能依赖b执行后的影响。

异步回调:
    把函数b传递给函数a。执行a的时候,回调了b,然后a就继续往后执行,b独自执行。
    执行a的时候,起一个线程去单独执行b,a继续往后执行

    
js选择了成为单线程的语言,所以它本身不可能是异步的,
但js的宿主环境(比如浏览器,Node)是多线程的,宿主环境通过某种方式使得js具备了异步的属性。
js是单线程语言,浏览器只分配给js一个主线程,用来执行任务(函数),
但一次只能执行一个任务,这些任务形成一个任务队列排队等候执行,
但前端的某些任务是非常耗时的,比如网络请求,定时器和事件监听,
如果让他们和别的任务一样,都老老实实的排队等待执行的话,执行效率会非常的低,甚至导致页面的假死。
所以,浏览器为这些耗时任务开辟了另外的线程,主要包括http请求线程,浏览器定时触发器,浏览器事件触发线程,这些任务是异步的。

浏览器为网络请求这样的异步任务单独开了一个线程,这些异步任务完成后,通过回调函数通知主线程。
整个程序是事件驱动的,每个事件都会绑定相应的回调函数,例如定时器:
    setTimeout(function(){
        console.log(time is out);
    },50);

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
同步非阻塞异步非阻塞是两种不同的函数调用方式。 同步非阻塞是指在发起函数调用后,调用方不会等待函数的结果返回,而是立即继续执行后续的代码。这意味着调用方无需等待函数的执行结果,可以继续处理其他任务。当函数执行完毕后,调用方可以通过轮询或者回调等方式来获取函数的结果。同步非阻塞的优点是能够提高系统的并发性和响应性。 异步非阻塞是指在发起函数调用后,调用方也不会等待函数的结果返回,但是与同步非阻塞不同的是,异步非阻塞会通过回调、事件通知等方式来通知调用方函数的执行结果。调用方可以继续执行其他任务,并在合适的时机处理函数的返回结果。异步非阻塞的优点是能够提高系统的并发性和性能,减少资源的浪费。 总结来说,同步非阻塞异步非阻塞都是在函数调用时不会发生线程阻塞的情况下继续执行后续代码,但区别在于同步非阻塞需要主动轮询或回调来获取函数的结果,而异步非阻塞则通过回调或事件通知等方式传递函数的执行结果。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [深入理解同步阻塞同步非阻塞异步阻塞异步非阻塞](https://blog.csdn.net/wangpaiblog/article/details/117236684)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值