Nodejs コールバックが深すぎます

WBOY
リリース: 2023-05-12 09:32:36
オリジナル
502 人が閲覧しました

開発中、特に Node.js でプログラミングする場合、コールバック地獄に遭遇することがよくあります。コールバック ヘルとは、入れ子になったコールバック関数の複数の層を指し、コードの保守、デバッグ、エラーのトラブルシューティングが困難になります。この記事では、Node.js コールバック 地獄の問題の原因とこの状況を解決する方法を分析します。

  1. コールバック地獄の問題はなぜ発生するのでしょうか?

Node.js は、イベント駆動型の非同期プログラミング モデルです。このモデルでは、ネットワーク リクエスト、ファイルの読み取りと書き込み、データベース クエリなどの I/O 操作はすべてノンブロッキング、つまり非同期で実行され、メイン プロセスの実行を中断しません。これにより、I/O 操作を待機する無駄な時間を回避し、プログラムのパフォーマンスを向上させることができます。しかし、非同期プログラミングの欠点は、コールバック地獄の問題が発生しやすいことです。

コールバック ヘル問題の主な原因は次のとおりです。

(1) Node.js はシングルスレッド モデルを採用しており、複数の I/O 操作を実行する場合、待機する必要があります。コールバック関数を介して結果を取得します。複数のネストされたコールバック関数でデータとロジックを処理すると、コードが複雑になります。

(2) 多くの Node.js モジュールとライブラリは非同期コールバック関数に基づいて設計されており、コールバック関数はこれらのモジュールとライブラリのメイン インターフェイスです。これらのモジュールとライブラリを使用する場合、コールバック関数へのネストされた呼び出しも行う必要があります。

(3) 非同期プログラミング モデルでは、I/O 操作が非同期で実行されるため、コールバック関数の実行順序が予期した順序と異なり、コード ロジックの複雑さが増加します。 。

  1. コールバック地獄の問題を解決するにはどうすればよいですか?

コールバック地獄の問題を解決するには、いくつかの非同期プログラミングのパターンと解決策を理解する必要があります。

(1) Promise の使用

Promise は、コールバック関数間で値を受け渡し、チェーンで呼び出すことができる非同期プログラミング モデルです。 Promise を使用すると、複数のネストされたコールバック関数を Promise チェーンに結合して、コードをより簡潔で読みやすくすることができます。以下は、Promise を使用してリファクタリングされたコード例です。

const fs = require('fs');

function readFilePromise(filename) {
  return new Promise((resolve, reject) => {
    fs.readFile(filename, 'utf-8', (err, data) => {
      if(err) reject(err);
      else resolve(data);
    });
  });
}

readFilePromise('file1.txt')
.then(data => {
  console.log(data);
  return readFilePromise('file2.txt');
})
.then(data => {
  console.log(data);
  return readFilePromise('file3.txt');
})
.then(data => {
  console.log(data);
})
.catch(err => console.log(err));
ログイン後にコピー

上記のコードでは、ファイル読み取りの非同期操作をラップするために Promise が使用され、複数の操作を接続するためにチェーン呼び出しが使用されているため、コードは不要になります。ネストされており、読みやすく、保守しやすい。

(2) async/await を使用する

async/await は ES2017 の新しい非同期プログラミング ソリューションであり、Promise に基づいて実装されています。 async 関数を使用すると、コードのロジックがより明確になり、人間の思考のロジックに沿ったものになります。以下は、async/await を使用してリファクタリングされたコード例です。

const fs = require('fs');

function readFilePromise(filename) {
  return new Promise((resolve, reject) => {
    fs.readFile(filename, 'utf-8', (err, data) => {
      if(err) reject(err);
      else resolve(data);
    });
  });
}

async function readFiles() {
  try {
    const data1 = await readFilePromise('file1.txt');
    console.log(data1);
    const data2 = await readFilePromise('file2.txt');
    console.log(data2);
    const data3 = await readFilePromise('file3.txt');
    console.log(data3);
  } catch(err) {
    console.log(err);
  }
}

readFiles();
ログイン後にコピー

上記のコードでは、async/await を使用して複数の非同期操作を連続的に実行し、await キーワードを使用して各非同期操作の前にコードを一時停止します。を実行し、Promise オブジェクトが結果を返すまで待ち​​ます。

(3) async モジュールを使用する

async は、非同期プログラミングをより簡単かつ便利にするためのいくつかの関数を提供するプロセス制御ライブラリです。 async ライブラリは、複数の制御フロー関数 (並列、ウォーターフォール、直列など) を提供します。これにより、複数の非同期操作を並列または直列に実行でき、結果をコールバック関数に返すことができます。以下は、async モジュールを使用したコード例です。

const async = require('async');
const fs = require('fs');

function readFile(filename, callback) {
  fs.readFile(filename, 'utf-8', (err, data) => {
    if(err) callback(err);
    else callback(null, data);
  });
}

async.series([
  function(callback) {
    readFile('file1.txt', callback);
  },
  function(callback) {
    readFile('file2.txt', callback);
  },
  function(callback) {
    readFile('file3.txt', callback);
  },
], function(err, results) {
  if(err) console.log(err);
  else console.log(results);
});
ログイン後にコピー

上記のコードでは、async.series 制御フロー関数を使用して、複数の非同期操作を連続して実行し、結果をコールバック関数に渡します。

  1. 概要

コールバック 地獄は Node.js プログラミングにおける一般的な問題であり、コードの保守、デバッグ、エラーのトラブルシューティングを困難にしています。コールバック 地獄の問題については、Promise、async/await、async モジュールなどのさまざまなソリューションを使用して、非同期プログラミングを最適化し、コードをより簡潔で読みやすくし、開発効率とコードの品質を向上させることができます。

以上がNodejs コールバックが深すぎますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!