Nodejs 异步又见异步
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 会依次执行事件队列中的事件,如果这个事件是异步的,就交给线程池来执行,然后继续执行下一个事件.线程池中的异步事件执行完毕后,会把这个事件的回调函数插入到事件队列的末尾.
最后,有什么不对的请指出.
回掉函数没有同步这种说法 所有的函数都是 push 到栈中执行 等 stack 执行完毕,就会去队列看看有没有要执行的 如此往复循环
那么如何理解setTimeOut((callback)=>{return callback},number)
number 时间之后添加到任务队列,等待执行。
没看清里面是个 callback,这个 callback 只是作为一个函数返回,不会运行 callback
在Node.js中,异步编程是其核心特性之一,使得Node.js在处理I/O密集型任务时表现出色。理解并善用异步机制,是高效使用Node.js的关键。
Node.js的异步操作主要通过回调函数、Promise和async/await来实现。以下是三种方式的简单示例:
- 回调函数:
const fs = require('fs');
fs.readFile('example.txt', 'utf8', (err, data) => {
if (err) throw err;
console.log(data);
});
- Promise:
const fs = require('fs').promises;
fs.readFile('example.txt', 'utf8')
.then(data => {
console.log(data);
})
.catch(err => {
console.error(err);
});
- 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中,推荐使用Promise
和async/await
来处理异步操作,因为它们提供了更清晰、更易读的代码结构,尤其是在处理多个异步操作时。此外,还可以使用一些辅助库,如axios
来处理HTTP请求,bluebird
来增强Promise的功能等。
总之,理解并善用Node.js的异步机制,可以大大提高代码的效率和可读性。