JavaScript异步和单线程经典的例子setTimeout
来源:互联网 发布:hbase快速清空表数据 编辑:程序博客网 时间:2024/05/22 04:58
这篇文章主要讲一下js的异步和单线程以及一个经典例子。
JavaScript是单线程和异步执行的。单线程的意思是一次只干一件事,所有要执行的任务都是排队一个个来。异步和同步是相对的,同步是说执行任务时要阻塞,上一个任务没有执行完,下一个任务不会执行。而异步会有所不同,当上一个任务需要等待时,会把该任务暂存起来,不会立即执行,等到所有程序执行完,处于空闲状态时,会立即查看有没有暂存的任务执行。
所以,我们知道当需要等待时就会发生异步。等待的场景主要有:
+ 定时任务:setTimeout, setInterval
+ 网络请求:ajax请求,图片img加载等
+ 绑定事件
下面讲一个关于setTimeout的经典例子。
console.log(1); setTimeout(function(){ console.log(2); },0); console.log(3);
上面程序运行的结果是1、3、2。如下图
现在分析一下程序的运行过程。
- 执行第一行,打印出1
- 执行setTimeout后,传入的函数会被暂存起来,不会立即执行(单线程的原因,不会同时干两件事)
- 执行第五行打印3
- 这时,所有程序执行完毕, 然后立即查看暂存的任务,这里暂存的任务是传入setTimeout的函数
- 发现setTimeout中的函数无需等待,就立即执行,打印2
所以可以知道,执行结果是1、3、2。
这篇文章就到这了,记录自己的学习心得,讲得比较简单,如有错误,恳请指正!
阅读全文
0 0
- JavaScript异步和单线程经典的例子setTimeout
- javascript的settimeout和异步
- JavaScript 的异步和单线程
- javascript异步和单线程
- 重新认识javascript的settimeout和异步
- 重新认识javascript的settimeout和异步
- JavaScript单线程(setTimeout,setInterval)
- JavaScript单线程 & setTimeout定时器
- setTimeout的异步以及js是单线程问题
- 对javascript异步和单线程的理解
- 理解JavaScript的单线程运行机制及setTimeout(fn,0)
- JavaScript单线程和异步机制
- javascript中的异步和单线程
- JavaScript单线程和异步机制
- javascript单线程 异步
- JavaScript是“单线程+异步”的
- 异步和单线程
- 异步和单线程
- Java技术图谱
- NLP深度学习 —— CS224学习笔记12
- HDU 3861 The King’s Problem(tarjan缩点+最小路径覆盖ISAP)
- html的meta标记大全
- js中的常用Math函数
- JavaScript异步和单线程经典的例子setTimeout
- 线程
- Ubuntu录制视频转GIF
- MTU & MSS 详解记录(转)
- 一只可爱的c++爬虫
- 回车执行js函数实现ajax调用
- search-a-2d-matrix
- systick使用出错总结
- js图片库——改进版