JavaScript 异步与同步

JavaScript 异步与同步

首先,说一下什么是异步,什么是同步。

具提详细的定义网上一大堆,我这里仅仅说下我个人的理解。

同步就是,只做一点事情,如果这个过程中需要等待,那么就空闲在哪里,等到得到了想要的结果再去继续处理别的事情。举个例子,在处理一些数据的时候,需要做一个网络请求,获得处理所需的一些东西。所以,要等到网络返回结果后接着去处理剩下的逻辑。

等待的结果是一个漫长的过程,万一没有结果呢?

所以,才有了异步。异步就是一事情做到一半,发现需要等待一段时间,这个时候我们把这个事情暂时放在一边。去作别的事情,等到空闲的时候再去看我们做到一半的事情,有没有具备条件可以寄继续执行。如果有那么就可以去执行它。

我们都知道JavaScript是一门同步执行的语言,但是我们在使用的时候却又很多异步的操作如settimeout, ajax等。这些操作是如何实现的呢?

线程和进程

进程

  • 程序运行的实例
  • 同一个程序可以产生多个进程
  • 一个进程可以包含一个或者多个线程

线程

  • 操作系统中能都进行运算调度的最小单位
  • 一次只能执行一个任务
  • 有自己的调用栈,寄存器环境
  • 同一个进程下的线程共享进程的资源

浏览器的进程

WX20200320-224418@2x.png
  • GUI线程 解析html,解析css,构建dom树等
  • js引擎线程,解析并执行js,与GUI线程互斥。长时间同步执行js会导致GUI线性停顿,从而感觉浏览器卡主了。
  • 定时器触发线程:settimeout setinterval
  • 事件触发线程:将满足调试的事件,放入任务队列
  • 网络线程:用于处理一些网络请求

定时器

代码

settimeout(() => {
  console.log('我执行了')
}, 2000)

上面就是我们使用定时器的一个简单示例,具体执行顺序入下。

  1. 调用webapi, 这个主要是要请求一个计时器,
  2. 定时器即使2s,
  3. 事件触发线程将时间翻入任务对了中
  4. 主线程通过eventLoop执行

eventLoop是一个任务队列,如果eventLoop中有元素,主线程会不断的轮询eventLoop中是否有元素,如果就将其取出并执行

定时器的弱点

  1. 定时器并不是严格准时的
  2. 定时器嵌套5次之后最小间隔不能低于4ms,不同的浏览器中有不同的实现。

定时器的使用场景

  1. 防抖 节流
  2. 倒计时
  3. 定时器动画,有可能出现丢帧

参考文章

https://www.ruanyifeng.com/blog/2013/04/processes_and_threads.html
https://juejin.im/post/5bd7c761518825292d6b0217

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,588评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,456评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,146评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,387评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,481评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,510评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,522评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,296评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,745评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,039评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,202评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,901评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,538评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,165评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,415评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,081评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,085评论 2 352

推荐阅读更多精彩内容