非同期プログラミングは、Goroutines と非同期 I/O を使用することで Go 言語アプリケーションのパフォーマンスを向上させます。Goroutines: 同時タスクを可能にする軽量のスレッドです。非同期 I/O: 呼び出しスレッドをブロックしないため、I/O リクエストの処理効率が向上します。実際の比較: 非同期アプリケーションの 1 秒あたりのリクエスト数は、同期アプリケーションのほぼ 2 倍です。
Go言語での非同期プログラミングがパフォーマンスに与える影響
はじめに
非同期プログラミングは、プログラム内のコードが関数呼び出しが完了するまで待つ必要がない同時プログラミングの一種です。実行を継続できます。これにより、アプリケーションはシステム リソースを最大限に活用できるようになり、応答性とスループットが向上します。
Go 言語では、非同期プログラミングは goroutine
を使用して実装されます。この記事では、Go 言語アプリケーションのパフォーマンスに対する非同期プログラミングの影響を調査し、実際のケースを通じてそれを実証します。 goroutine
实现了异步编程。本文将探討异步编程对 Go 语言应用程序性能的影响,并通过一个实战案例进行演示。
goroutine
goroutine
是 Go 语言中的轻量级线程。与传统线程不同,goroutine
具有更低的开销,这使得 Go 语言应用程序可以同时处理大量并发任务。
创建 goroutine
goroutine
goroutin
は Go 言語の軽量スレッドです。従来のスレッドとは異なり、goroutine
はオーバーヘッドが低いため、Go 言語アプリケーションは同時に多数の同時タスクを処理できます。
goroutine
を作成するための構文は次のとおりです。 go func() { // 代码块 }
実践的なケース
実際的なケースを使用して、Go 言語アプリケーションのパフォーマンスに対する非同期プログラミングの影響を実証してみましょう。 2 つのアプリケーションを作成します。1 つは同期コードを使用し、もう 1 つは Web リクエスト用の非同期コードを使用します。
同期コード
import ( "fmt" "net/http" ) func main() { resp, err := http.Get("https://example.com") if err != nil { fmt.Println(err) return } defer resp.Body.Close() _, err = io.Copy(ioutil.Discard, resp.Body) if err != nil { fmt.Println(err) return } }
非同期コード
Apache Benchmarkを使用して、両方のアプリケーションのパフォーマンステストを実行しました。テスト結果は次のとおりです。 | |
---|---|
1 秒あたりのリクエスト数 | |
同期 | 10,000 |