node.js异步编程

node.js 异步编程

1. 同步API

只有当前API执行完成后,才能继续执行下一个API

2.异步API

当前API的执行不会阻塞后续代码的执行

3.同步API与异步API的区别

同步API可以从返回值中拿到API执行的结果, 但是异步API是不可以的;异步API一般都是通过回调函数获取其执行的结果;同步API从上到下依次执行,前面代码会阻塞后面代码的执行;异步API不会等待API执行完成后再向下执行代码。正常的Js代码执行顺序都是先执行同步代码再执行异步代码。

/************同步API代码*****************/
for (var i = 0; i < 10000; i++) {
    console.log(i);

}
console.log('for循环后面的代码');
// 执行结果:先打印0-9999,再打印‘for循环后面的代码’

/****************异步API代码****************/
console.log('before');
setTimeout(() => {
    console.log('last');
});
console.log('after');
// 执行结果:before after last

4.回调函数之回调地狱

/*************示例代码***************/
// 1.txt
这是文件1
// 2.txt
这是文件2
// 3.txt
这是文件3
const fs = require('fs');

fs.readFile('./1.txt', 'utf-8', (err, result1) => {
    console.log(result1);
    fs.readFile('./2.txt', 'utf-8', (err, result2) => {
        console.log(result2);
        fs.readFile('./3.txt', 'utf-8', (err, result3) => {
            console.log(result3);
        });
    });
});

回调函数中嵌套回调是代码中比较常用的情况,但是在大量的回调函数中嵌套使用回调将会陷入回调地狱。

5.promise
promise的作用是解决node中异步编程的回调地狱问题,promise支持链式编程

/***********代码示例************/
const fs = require('fs');

let promise = new Promise((resolve, reject) => {
    fs.readFile('./1.txt', 'utf-8', (err, result) => {
        if (err != null) {
            reject(err);
        } else {
            resolve(result);
        }
    });
});

promise.then((result) => {
        console.log(result); // 当1.txt存在时显示时1.txt内容 => 这是文件1
    })
    .catch((err) => {
        console.log(err); // 当1.txt不存在或者发生错误时,显示错误信息
    });

6.异步函数
异步函数是解决异步编程的最好方案,它可以让我们将异步代码写成同步的形式,让代码不再有回调函数嵌套,使代码变得清晰明了。

/***********使用方法**********/
const fs = require('fs');
// 使用promisify()需要依赖 util 模块
const promisify = require('util').promisify;
// promisify()用于改造node.js中的现有异步api,让其返回promise对象,从而可以使用异步函数语法
const readFile = promisify(fs.readFile);

async function read() {
    let r1 = await readFile('./1.txt', 'utf-8');
    let r2 = await readFile('./2.txt', 'utf-8');
    let r3 = await readFile('./3.txt', 'utf-8');
    console.log(r1);
    console.log(r2);
    console.log(r3);
}
read();

异步函数总结:
async 关键字

  1. 普通函数定义前加async关键字 普通函数变成异步函数
  2. 异步函数默认返回promise对象
  3. 在异步函数内部使用return关键字进行结果返回 结果会被包裹的promise对象中 return关键字代替了resolve方法
  4. 在异步函数内部使用throw关键字抛出程序异常
  5. 调用异步函数再链式调用then方法获取异步函数执行结果
  6. 调用异步函数再链式调用catch方法获取异步函数执行的错误信息

await 关键字

  1. await关键字只能出现在异步函数中
  2. await promise await后面只能写promise对象 写其他类型的API是不不可以的
  3. await关键字可是暂停异步函数向下执行 直到promise返回结果
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值