同步和异步

同步和异步

  1. 同步

概念:代码从上往下依次执行,前面的代码没有执行完毕,后面的代码不会执行,可能会造成代码堵塞

通过一个案例来理解

代码实现:

console.log(111)
for(let i = 0; i < 1000; i++){
	console.log(222)
}
console.log(333)

在VSCode中编译运行
在这里插入图片描述
可以看到在执行到for循环的时候执行了1000次,在没有执行完for循环的时候不会执行后面的代码,如果执行次数更多的话,可能会造成代码堵塞


  1. 异步

概念:代码从上往下执行,如果遇到异步代码,就会把异步代码放到最后,先把所有的同步代码执行完毕后,在依次执行异步代码

异步的三种情形:
1. 定时器的回调函数
2. 事件的回调函数
3. Ajax请求的响应的回调函数(Ajax请求的响应顺序是不可控的)
Ajax发送请求详情请访问

通过一个案例来理解
代码实现:

console.log(111)
//定时器的回调函数
setTimeout(function(){
	console.log(222)
},2000)

//事件的回调函数
window.onload = function(){
	console.log(333)	
}

//ajax的请求的响应的回调函数
let xhr = new XMLHttpRequest()
xhr.open('get', 'http://localhost:8888/test/first')
xhr.send()
xhr.onreadystatechange = function (){
	if(xhr.readyState == 4 && xhr.status == 200){
		//请求成功就打印
		console.log(444)
	}
}
console.log(555)

在VSCode中编译运行
在这里插入图片描述
可以看到案例中先是执行同步代码,遇到异步代码先放到最后,在同步代码执行完毕后再依次去执行异步代码(异步代码存在执行顺序)

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值