HTTP ハンドラー内で goroutine を実行する場合、応答が返された後も実行が継続されるかどうか疑問に思うのは自然なことです。次のコード例を考えてみましょう。
package main import ( "fmt" "net/http" "time" ) func worker() { fmt.Println("worker started") time.Sleep(time.Second * 10) fmt.Println("worker completed") } func HomeHandler(w http.ResponseWriter, r *http.Request) { go worker() w.Write([]byte("Hello, World!")) } func main() { http.HandleFunc("/home", HomeHandler) http.ListenAndServe(":8081", nil) }
このコードは、印刷が完了する前に 10 秒間スリープする HomeHandler 内で goroutine をスピンアップします。応答が書き込まれると、メインのゴルーチンは HomeHandler 関数から戻ります。
この特定のシナリオでは、ゴルーチンは実際に実行を完了し、ステートメント「worker」を出力します。 「開始しました」と「ワーカーが完了しました」がコンソールに表示されます。これは次の理由によるものです。
この場合、ゴルーチンを途中で終了する唯一の方法は、実行中のような不安定な状態に遭遇することです。メモリ不足を解決するか、同期手法を使用して goroutine を明示的に停止します (このコード例では説明されていません)。
以上がHTTP 応答が送信された後、Goroutine は終了しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。