简单谈谈JavaScript的同步与异步
作者:bea
1.手绘一张图说明。 2.为什么JavaScript是单线程(这里引用阮一峰老师的话) JavaScript的单线程,与它的用途有关。 作为浏览器脚本语言,JavaScript的主要用途是与用户互动,以及操作DOM。 这决定了它只能是单线程,否则会带来很复杂的同步问题。 比如,假定JavaScript同时有两个线程,一个线程在某个DOM节点上添加内容,另一个线程删除了这个节点,这时浏览器应该以哪个线程为准? 所以,为了避免复杂性,从一诞生,JavaScript就是单线程,
1.手绘一张图说明。
2.为什么JavaScript是单线程(这里引用阮一峰老师的话)
JavaScript的单线程,与它的用途有关。
作为浏览器脚本语言,JavaScript的主要用途是与用户互动,以及操作DOM。
这决定了它只能是单线程,否则会带来很复杂的同步问题。
比如,假定JavaScript同时有两个线程,一个线程在某个DOM节点上添加内容,另一个线程删除了这个节点,这时浏览器应该以哪个线程为准?
所以,为了避免复杂性,从一诞生,JavaScript就是单线程,这已经成了这门语言的核心特征,将来也不会改变。
为了利用多核CPU的计算能力,HTML5提出Web Worker标准,允许JavaScript脚本创建多个线程,但是子线程完全受主线程控制,且不得操作DOM。
所以,这个新标准并没有改变JavaScript单线程的本质。
传送门:JavaScript运行机制之事件循环(Event Loop)详解
3.JavaScript的异步体现在哪
如一开始的图,个人认为左边主线程就是同步,左边事件队列(消息队列)就是异步。
当然JavaScript中的异步有很多:
Ajax(XMLHttpRequest)
Image Tag,Script Tag,iframe(原理类似)
setTimeout/setInterval
CSS3 Transition/Animation
postMessage
Web Workers
Web Sockets
and more…
猜你喜欢
您可能感兴趣的文章:
- 快速学习AngularJs HTTP响应拦截器
- 常见的javascript跨域通信方法
- javascript实现input file上传图片预览效果
- 分享几种比较简单实用的JavaScript tabel切换
- jQuery+ajax实现文章点赞功能的方法
- jQuery实现的超简单点赞效果实例分析
- jQuery实现的给图片点赞+1动画效果(附在线演示及demo源码下载)
- jQuery实现的点赞随机数字显示动画效果(附在线演示与demo源码下载)
- AngularJS中实现显示或隐藏动画效果的方式总结
- javascript数据类型验证方法
- jQuery操作基本控件方法实例分析
- javascript图片延迟加载实现方法及思路
- jQuery动画显示和隐藏效果实例演示(附demo源码下载)
- 详解javascript高级定时器
- jQuery动画效果相关方法实例分析
- js实现文字垂直滚动和鼠标悬停效果
- jquery正则表达式验证(手机号、身份证号、中文名称)
- jQuery语法小结(超实用)
- 解决JS无法调用Controller问题的方法