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");
});
相关推荐
崇山峻岭之间6 分钟前
Matlab学习记录20
开发语言·学习·matlab
逍遥德9 分钟前
JPA 操作对象图 (Object Graph) 详解
开发语言·python
微爱帮监所写信寄信15 分钟前
微爱帮监狱寄信写信小程序信件内容实时保存技术方案
java·服务器·开发语言·前端·小程序
李少兄22 分钟前
时间戳转换工具
开发语言·javascript·工具
这是个栗子22 分钟前
【Vue代码分析】vue方法的调用与命名问题
前端·javascript·vue.js·this
ss27328 分钟前
CompletionService:Java并发工具包
java·开发语言·算法
全栈前端老曹31 分钟前
【前端路由】Vue Router 动态导入与懒加载 - 使用 () => import(‘...‘) 实现按需加载组件
前端·javascript·vue.js·性能优化·spa·vue-router·懒加载
额呃呃32 分钟前
select和poll之间的性能对比
开发语言·算法
温宇飞33 分钟前
高效的线性采样高斯模糊
javascript·webgl
智航GIS33 分钟前
7.2 Try Except语句
开发语言·python