Node で非同期関数を使用する方法について話しましょう

青灯夜游
リリース: 2022-12-20 21:16:21
転載
2021 人が閲覧しました

新しいバージョンの V8 エンジンでは、Node は 7.6 以降の非同期関数機能をサポートします。今年 10 月 31 日には、Node.js 8 も新しい長期サポート バージョンになったので、コード内で非同期関数を安心して使用できるようになりました。この記事では、非同期関数とは何か、また非同期関数によって Node.js アプリケーションの作成方法がどのように変わるかを簡単に紹介します。

Node で非同期関数を使用する方法について話しましょう

async 関数とは

async 関数を使用すると、同期コードと同じように Promise ベースの非同期コードを作成できます。 async キーワードを使用して関数を定義すると、関数内で await キーワードを使用できるようになります。非同期関数が呼び出されると、Promise が返されます。 async 関数が値を返すと、Promise は満たされますが、関数内でエラーがスローされた場合、Promise は拒否されます。 [関連チュートリアルの推奨事項: nodejs ビデオ チュートリアル プログラミング教育 ]

await キーワードを使用すると、Promise が解決されるのを待機し、その実現された値を返すことができます。 await に渡された値が Promise ではない場合、値は解決された Promise に変換されます。

const rp = require('request-promise')
async function main () {
 const result = await rp('https://google.com')
 const twenty = await 20
 // 睡个1秒钟
 await new Promise (resolve => {
  setTimeout(resolve, 1000)
 })
 return result
}
main()
 .then(console.log)
 .catch(console.error)
ログイン後にコピー

非同期関数への移行

Node.js アプリケーションがすでに Promise を使用している場合は、元のチェーン呼び出しを These Promise await に書き直すだけで済みます。

アプリケーションがまだコールバック関数を使用している場合は、非同期関数の使用に徐々に切り替える必要があります。いくつかの新機能を開発するときに、この新しいテクノロジーを使用できます。古いコードを呼び出す必要がある場合は、それを Promise にラップして、新しい方法で呼び出すだけです。

これを行うには、組み込みの util.promisify メソッドを使用できます。

const util = require('util')
const {readFile} = require('fs')
const readFileAsync = util.promisify(readFile)
async function main () {
 const result = await readFileAsync('.gitignore')
 return result
}
main()
 .then(console.log)
 .catch(console.error)
ログイン後にコピー

3 非同期関数のベスト プラクティス

Express での非同期関数の使用

express は元々 Promise をサポートしているため、Express での非同期関数の使用は比較的簡単です:

const express = require('express')
const app = express()
app.get('/', async (request, response) => {
 // 在这里等待 Promise
 // 如果你只是在等待一个单独的 Promise,你其实可以直接将将它作为返回值返回,不需要使用 await 去等待。
 const result = await getContent()
 response.send(result)
})
app.listen(process.env.PORT)
ログイン後にコピー

しかし、Keith Smith が指摘したように、上の例 - Promise が最終的に拒否された場合、ここではエラー処理がないため、Express Route プロセッサがハングします。

この問題を解決するには、エラーを処理する関数で非同期ハンドラーをラップする必要があります。

const awaitHandlerFactory = (middleware) => {
 return async (req, res, next) => {
  try {
   await middleware(req, res, next)
  } catch (err) {
   next(err)
  }
 }
}
// 然后这样使用:
app.get('/', awaitHandlerFactory(async (request, response) => {
 const result = await getContent()
 response.send(result)
}))
ログイン後にコピー

並列実行

# #たとえば、次のようになります。操作に 2 つの入力 (1 つはデータベースから、もう 1 つは外部サービスから) を必要とするプログラムを作成します。

async function main () {
 const user = await Users.fetch(userId)
 const product = await Products.fetch(productId)
 await makePurchase(user, product)
}
ログイン後にコピー

この例では、何が起こるでしょうか?

あなたのコードは最初にユーザーを取得し、

次に製品を取得し、

最後に支払いを行います。

ご覧のとおり、最初の 2 つのステップの間には相互依存関係がないため、実際にはこれらを並行して実行できます。ここでは、Promise.all メソッドを使用する必要があります:

async function main () {
 const [user, product] = await Promise.all([
  Users.fetch(userId),
  Products.fetch(productId)
 ])
 await makePurchase(user, product)
}
ログイン後にコピー
そして、最も速く解決された Promise の戻り値のみが必要な場合もあります。この場合は、Promise.race メソッドを使用できます。

ノード関連の知識の詳細については、

nodejs チュートリアル を参照してください。

以上がNode で非同期関数を使用する方法について話しましょうの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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