Nodejs 异步又见异步

发布于 1周前 作者 phonegap100 来自 nodejs/Nestjs

Nodejs 异步又见异步

浏览器中的 JavaScript

在浏览器中 js 是单线程的,同步的.

xmlHttpRequest 是一个特殊情况.

xmlHttpRequest 由浏览器新开线程实现异步.

setTimeOut 本身是异步的.

但 setTimetOut 只不过是在计时完成后把 function 扔到了执行队列最末尾,function 仍然和队列同步执行,所以会出现计时器计时完成后 function 不执行的情况.

回调函数是同步的.

回调函数是同步的.

回调函数是同步的.

重复三遍,敲黑板,划重点.

node.js 中的 JavaScript

不使用 node.js 异步 APi

这种情况下,和浏览器没什么区别,不过 node 本身没有 xmlhttpRequest.

node.js 异步 api

node.js 有一个事件队列和一个线程池

node.js 会依次执行事件队列中的事件,如果这个事件是异步的,就交给线程池来执行,然后继续执行下一个事件.线程池中的异步事件执行完毕后,会把这个事件的回调函数插入到事件队列的末尾.

最后,有什么不对的请指出.


5 回复

回掉函数没有同步这种说法 所有的函数都是 push 到栈中执行 等 stack 执行完毕,就会去队列看看有没有要执行的 如此往复循环


那么如何理解

setTimeOut((callback)=>{return callback},number)

number 时间之后添加到任务队列,等待执行。

没看清里面是个 callback,这个 callback 只是作为一个函数返回,不会运行 callback

在Node.js中,异步编程是其核心特性之一,使得Node.js在处理I/O密集型任务时表现出色。理解并善用异步机制,是高效使用Node.js的关键。

Node.js的异步操作主要通过回调函数、Promise和async/await来实现。以下是三种方式的简单示例:

  1. 回调函数
const fs = require('fs');

fs.readFile('example.txt', 'utf8', (err, data) => {
    if (err) throw err;
    console.log(data);
});
  1. Promise
const fs = require('fs').promises;

fs.readFile('example.txt', 'utf8')
    .then(data => {
        console.log(data);
    })
    .catch(err => {
        console.error(err);
    });
  1. async/await
const fs = require('fs').promises;

async function readFile() {
    try {
        const data = await fs.readFile('example.txt', 'utf8');
        console.log(data);
    } catch (err) {
        console.error(err);
    }
}

readFile();

在Node.js中,推荐使用Promiseasync/await来处理异步操作,因为它们提供了更清晰、更易读的代码结构,尤其是在处理多个异步操作时。此外,还可以使用一些辅助库,如axios来处理HTTP请求,bluebird来增强Promise的功能等。

总之,理解并善用Node.js的异步机制,可以大大提高代码的效率和可读性。

回到顶部