nodejs チュートリアル 非同期 I/O_node.js
はしがき
私のイメージでは、非同期は ajax で初めて登場しました。当時私はまだ .net を開発していましたが、実際に .net には非同期コントロールが登場しました。
ようやく非同期ではないことが分かりましたが… では、フロントエンドは非同期で多用されているので、非同期プログラムでないと、自分が書いたNodeJを作ったと言うのは恥ずかしいことになります。 JavaScript による
非同期プログラミング モデルの機能も引き継がれていますが、非同期には多くの利点がありますが、設計にとっては悪夢です。そのため、設計の難易度が高くなります。
しかし、非同期はパフォーマンスの向上とユーザーエクスペリエンスに革命をもたらしました。そのため、今日は NodeJS の非同期機能を簡単に学びます。
非同期 I/O
実際、オペレーティング システム レベルでは、I/O メソッドはブロッキングとノンブロッキングの 2 つだけです
ブロッキング モデルでは、アプリケーションは結果を返す前に I/O が完了するまで待つ必要があり、その特徴はバックエンドを呼び出し、システムがすべての操作を完了するまで待機することです。ノンブロッキング呼び出しはすぐに返されますので、お待ちください。
初めて本を読みましたが、ここでの説明が明確ではないと感じました。非同期モデルは実際には非常に大きく、認識のレベルが向上しただけです。簡単な例を示します。
現在、検索ページとリスト ページの 2 つの単一ページ アプリケーション ビューがあり、検索する際には、さまざまなチャネルを通じて検索する必要があり、サードパーティは特定のチャネルからデータを取得します。
もちろん、現時点では非常に遅いです。A から B に直接切り替えてから、B にデータをロードするためのローディング ボックスなどを作成しても問題はありません。しかし、問題はアニメーションが必要なことです。 A から B に切り替えるエフェクト
これには、切り替え時に Bview レンダリングが終了している必要があります。少なくとも、プロセス内でデータを取得してレンダリングを開始することはできないため、現時点では、非同期でデータを要求する場合でも、非同期を使用するのはそれほど簡単ではない可能性があります。ページをロードするためのデータ取得
これは依然として読み込みをブロックしており、ビジネスの観点からこれを行う方法はありません
完璧なテクノロジーはありません。ブロックすると CPU 待機の無駄が発生するだけでなく、ロードが完了したかどうかを確認するためにポーリングが必要になる場合もあります (DOM が生成されたかどうかを検出するためにポーリングを使用したことがあります)。
NodeJs は、プロセスが開始されると無限ループを作成します。各 Tick のプロセスは、必要なイベントがあるかどうかを確認します。処理予定
存在する場合は、関連するイベントを取り出して実行し、存在しない場合はループを終了します
。各 Tick プロセスでは、各イベント ループに 1 つ以上のオブザーバーがあり、処理するイベントがあるかどうかを判断するプロセスでは、イベントを処理する必要があるかどうかをこれらのオブザーバーに尋ねます。
HTML イベント モデルを例に挙げてみましょう
実際、HTML の場合、その各 DOM は Web ページの変更を監視します。DOM に addEventListener を提供した後、そのイベントのコールバック関数を登録します。登録したものは「コンテナ」オブジェクトに入れられます。現時点では、これらの関数は条件が満たされた後 (ページが変更されたとき) にトリガーされ、関連するイベントがコンテナから取得されます。実行されました
ここで、ページ上のポイントを 1 回クリックし、コンテナからクリック イベント コレクションを取り出し、関連する DOM を見つけて、これらの DOM のコールバック関数をトリガーします
イベントは、ユーザーのクリックまたはデータ変更から発生する可能性があります。Node では、イベントは主にネットワーク リクエストやファイル I/O から発生します。これらのイベントには、ファイル オブザーバーやネットワーク オブザーバーなどの対応するオブザーバーがあります。
これも典型的な生産/消費モデルです。非同期 I/O、ネットワーク リクエストによりイベントが生成され、イベントはさまざまなオブザーバーに配信され、オブザーバーはイベントを登録します。イベント ループはイベントの取り出しと実行を担当します。
追記: クリックを例に挙げると、各 DOM オブザーバーが最初にイベントを登録し、ページプロセスがページを継続的に監視し、ユーザーがページをクリックしてイベントを生成し、登録されたクリックイベントがコンテナから取得されて実行されます。 、
一般的な関数ロジックは当社によって制御されます:
var forEach = 関数 (リスト、コールバック) {
for (var i = 0, len = list.length; i callback(list[i], i, list);
}
}
非同期操作の場合、コールバック関数は開発者によって制御されません。js が呼び出されるたびに、移行製品リクエスト オブジェクトが生成されます。
fs.open = 関数 (パス、フラグ、モード、コールバック) {
bingding.open(pathModule._makeLong(path), stringToFlags(flags), モード, コールバック);
};
fs.open は、パスとパラメータに基づいてファイルを開き、関連するデータを取得します。内部的に c 関連インターフェイスを呼び出します。プロセス内で中間オブジェクトが生成され、その中ですべての状態が...
追伸: ずっと見ていると気分が悪くなりました
結論
以上はnodejsの非同期I/Oに関する個人的なまとめです。抜けや間違いがあればご指摘ください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Node.js と Tomcat の主な違いは次のとおりです。 ランタイム: Node.js は JavaScript ランタイムに基づいていますが、Tomcat は Java サーブレット コンテナです。 I/O モデル: Node.js は非同期ノンブロッキング モデルを使用しますが、Tomcat は同期ブロッキング モデルです。同時実行処理: Node.js はイベント ループを通じて同時実行を処理しますが、Tomcat はスレッド プールを使用します。アプリケーション シナリオ: Node.js はリアルタイム、データ集約型、同時実行性の高いアプリケーションに適しており、Tomcat は従来の Java Web アプリケーションに適しています。

Node.js はサーバー側の JavaScript ランタイムであり、Vue.js は対話型ユーザー インターフェイスを作成するためのクライアント側の JavaScript フレームワークです。 Node.js はバックエンド サービス API 開発やデータ処理などのサーバー側開発に使用され、Vue.js はシングルページ アプリケーションや応答性の高いユーザー インターフェイスなどのクライアント側開発に使用されます。

Node.js は、高いパフォーマンス、スケーラビリティ、クロスプラットフォーム サポート、豊富なエコシステム、開発の容易さなどの機能を備えているため、バックエンド フレームワークとして使用できます。

はい、Node.js はバックエンド開発言語です。これは、サーバー側のビジネス ロジックの処理、データベース接続の管理、API の提供などのバックエンド開発に使用されます。

Node.js インストール ディレクトリには、npm と npm.cmd という 2 つの npm 関連ファイルがあります。違いは次のとおりです。拡張子が異なります。npm は実行可能ファイルで、npm.cmd はコマンド ウィンドウのショートカットです。 Windows ユーザー: npm.cmd はコマンド プロンプトから使用できますが、npm はコマンド ラインからのみ実行できます。互換性: npm.cmd は Windows システムに固有ですが、npm はクロスプラットフォームで使用できます。使用上の推奨事項: Windows ユーザーは npm.cmd を使用し、他のオペレーティング システムは npm を使用します。

Node.js には次のグローバル変数が存在します。 グローバル オブジェクト: グローバル コア モジュール: プロセス、コンソール、require ランタイム環境変数: __dirname、__filename、__line、__column 定数: unknown、null、NaN、Infinity、-Infinity

Node.js と Java の主な違いは、設計と機能です。 イベント駆動型とスレッド駆動型: Node.js はイベント駆動型で、Java はスレッド駆動型です。シングルスレッドとマルチスレッド: Node.js はシングルスレッドのイベント ループを使用し、Java はマルチスレッド アーキテクチャを使用します。ランタイム環境: Node.js は V8 JavaScript エンジン上で実行され、Java は JVM 上で実行されます。構文: Node.js は JavaScript 構文を使用し、Java は Java 構文を使用します。目的: Node.js は I/O 集中型のタスクに適しており、Java は大規模なエンタープライズ アプリケーションに適しています。

Web 開発において Node.js と Java にはそれぞれ長所と短所があり、どちらを選択するかはプロジェクトの要件によって異なります。 Node.js はリアルタイム アプリケーション、迅速な開発、マイクロサービス アーキテクチャに優れており、Java はエンタープライズ グレードのサポート、パフォーマンス、セキュリティに優れています。
