JavaScript高级(十八)---进程和线程,宏任务和微任务

进程和线程

进程(process):计算机已经运行的程序,是操作系统管理程序的一种方式,我们可以认为,启动一个应用程序,就会默认启动一个进程(也可能是多个进程)。

线程(thread):操作系统能够运行运算调度的最小单位 ,通常情况下它被包含在进程中 ,每一个进程中 都至少启动一个线程来执行应用程序的代码,这个线程被称为主线程

宏任务微任务

宏任务队列(macrotask queue):ajax、setTimeout、setInterval、DOM监听、UI Rendering等

微任务队列(microtask queue):Promise的then回调、 Mutation Observer API、queueMicrotask()等

面试题:

javascript 复制代码
setTimeout(function () {
  console.log("setTimeout1");
  new Promise(function (resolve) {
    resolve();
  }).then(function () {
    new Promise(function (resolve) {
      resolve();
    }).then(function () {
      console.log("then4");
    });
    console.log("then2");
  });
});

new Promise(function (resolve) {
  console.log("promise1");
  resolve();
}).then(function () {
  console.log("then1");
});

setTimeout(function () {
  console.log("setTimeout2");
});

console.log(2);

queueMicrotask(() => {
  console.log("queueMicrotask1")
});

new Promise(function (resolve) {
  resolve();
}).then(function () {
  console.log("then3");
});
相关推荐
打瞌睡的朱尤4 小时前
Vue day10 完整购物网页(登录页,首页,搜索)
前端·javascript·vue.js
光泽雨4 小时前
C# 中 Assembly 类详解
开发语言·c#
少控科技5 小时前
C#基础训练营 - 02 - 运算器
开发语言·c#
扶苏10025 小时前
深入理解 Vue 3 的 watchEffect
前端·javascript·vue.js
Riemann~~5 小时前
C语言嵌入式风格
c语言·开发语言
zmzb01037 小时前
C++课后习题训练记录Day104
开发语言·c++
zmzb01038 小时前
C++课后习题训练记录Day105
开发语言·c++·算法
wjs20248 小时前
Vue3 条件语句
开发语言
_codemonster8 小时前
JavaWeb开发系列(六)JSP基础
java·开发语言
yanlele8 小时前
AI Coding 时代下, 关于你会写代码这件事儿, 还重要吗?
前端·javascript·ai编程