久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > 在Go語言中使用context實現(xiàn)超時控制

在Go語言中使用context實現(xiàn)超時控制

來源:千鋒教育
發(fā)布人:xqq
時間: 2023-12-24 15:00:49 1703401249

在Go語言中使用context實現(xiàn)超時控制

在開發(fā)網(wǎng)絡應用程序時,我們經(jīng)常需要控制I/O操作或網(wǎng)絡請求的超時時間,以避免長時間等待導致程序出現(xiàn)性能問題或者死鎖現(xiàn)象。而Go語言標準庫中提供了一種非常方便的方式來實現(xiàn)超時控制,那就是使用context包。

Context是一種線程安全的數(shù)據(jù)結(jié)構(gòu),它包含了一個上下文環(huán)境,可以被多個goroutine共享。在Go語言中,每個goroutine都可以使用context,通過使用context包,我們可以將context傳遞給子goroutine中,以便在子goroutine中使用context來控制超時時間。

一、使用context控制超時

我們可以使用context.WithTimeout方法來創(chuàng)建一個具有超時時間的context,當超時時間到達時,context將自動取消,此時所有使用該context進行的操作都將停止,并返回一個error:context deadline exceeded。下面是一個示例代碼:

`go

package main

import (

"context"

"fmt"

"time"

)

func main() {

// 創(chuàng)建一個具有5秒超時時間的context

ctx, cancel := context.WithTimeout(context.Background(), time.Second*5)

defer cancel()

// 模擬一個需要耗時10秒的操作

go func() {

time.Sleep(time.Second * 10)

}()

// 在此處使用context進行操作,并檢測是否超時

select {

case <-ctx.Done():

fmt.Println("超時:", ctx.Err())

case <-time.After(time.Second * 6):

fmt.Println("超時時間已到")

}

}

在上面的示例代碼中,我們使用context.WithTimeout方法創(chuàng)建了一個具有5秒超時時間的context,并使用time.Sleep方法模擬了一個需要耗時10秒的操作。在select語句中,我們使用<-ctx.Done()來檢測是否超時,當超時時間到達時,會輸出“超時:context deadline exceeded”;而當超時時間未到達時,會輸出“超時時間已到”。二、使用context控制多個goroutine我們可以使用context.WithCancel方法來創(chuàng)建一個可以被取消的context,并將該context傳遞給多個子goroutine中,以便統(tǒng)一控制這些goroutine的退出。下面是一個示例代碼:`gopackage mainimport ("context""fmt""time")func worker(ctx context.Context) {// 模擬一個需要耗時的任務for {select {case <-ctx.Done():returndefault:time.Sleep(time.Second)fmt.Println("working...")}}}func main() {    // 創(chuàng)建一個可以被取消的contextctx, cancel := context.WithCancel(context.Background())defer cancel()    // 啟動3個goroutine,并傳遞給它們同一個contextfor i := 0; i < 3; i++ {go worker(ctx)}    // 模擬任務執(zhí)行5秒,然后取消contexttime.Sleep(time.Second * 5)cancel()select {case <-time.After(time.Second * 3):fmt.Println("超時退出")case <-ctx.Done():fmt.Println("任務取消:", ctx.Err())}}

在上面的示例代碼中,我們使用context.WithCancel方法創(chuàng)建了一個可以被取消的context,并將該context傳遞給了3個子goroutine。每個子goroutine會模擬一個需要耗時的任務,當context被取消時,每個子goroutine都會退出。

三、使用context控制http請求

我們可以使用http.NewRequestWithContext方法來創(chuàng)建一個具有超時時間的http請求。這個方法接收一個context作為參數(shù),并返回一個請求對象。下面是一個示例代碼:

`go

package main

import (

"context"

"fmt"

"io/ioutil"

"net/http"

"time"

)

func main() {

// 創(chuàng)建一個具有5秒超時時間的context

ctx, cancel := context.WithTimeout(context.Background(), time.Second*5)

defer cancel()

// 創(chuàng)建一個具有超時時間的http請求

req, err := http.NewRequestWithContext(ctx, http.MethodGet, "https://www.baidu.com", nil)

if err != nil {

fmt.Println("創(chuàng)建請求失敗:", err)

return

}

// 發(fā)送http請求,并檢測是否超時

client := &http.Client{}

resp, err := client.Do(req)

if err != nil {

fmt.Println("發(fā)送請求失敗:", err)

return

}

defer resp.Body.Close()

result, err := ioutil.ReadAll(resp.Body)

if err != nil {

fmt.Println("讀取響應數(shù)據(jù)失敗:", err)

return

}

fmt.Println("響應數(shù)據(jù):", string(result))

}

在上面的示例代碼中,我們使用http.NewRequestWithContext方法創(chuàng)建了一個具有5秒超時時間的http請求,并使用http.Client的Do方法發(fā)送該請求。當超時時間到達時,http請求將自動取消,并返回一個error:net/http: request canceled while waiting for response headers。

總結(jié)

在本文中,我們介紹了如何使用context包來實現(xiàn)超時控制。通過使用context包,我們可以非常方便地控制I/O操作、網(wǎng)絡請求、goroutine等的超時時間,完整的示例代碼和實現(xiàn)細節(jié)也在本文中給出,希望可以幫助到大家。

以上就是IT培訓機構(gòu)千鋒教育提供的相關內(nèi)容,如果您有web前端培訓,鴻蒙開發(fā)培訓python培訓,linux培訓,java培訓,UI設計培訓等需求,歡迎隨時聯(lián)系千鋒教育。

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
理解golang中的channel并發(fā)機制

理解Go語言中的Channel并發(fā)機制作為一門同時支持并發(fā)和并行的編程語言,Go語言提供了許多同步機制,其中Channel是其中最重要的一種。在Go語言中...詳情>>

2023-12-24 16:28:47
從零開始Golang中的Web開發(fā)入門指南

從零開始:Golang中的Web開發(fā)入門指南隨著互聯(lián)網(wǎng)的不斷發(fā)展,Web 開發(fā)已經(jīng)成為了非常熱門的職業(yè)。對于想要了解 Web 開發(fā)的初學者來說,Golang ...詳情>>

2023-12-24 16:19:59
獨特的網(wǎng)絡安全技術,打造最安全的網(wǎng)絡世界

獨特的網(wǎng)絡安全技術,打造最安全的網(wǎng)絡世界——網(wǎng)絡安全技術的未來發(fā)展隨著網(wǎng)絡技術的不斷發(fā)展,網(wǎng)絡安全問題也越來越重要。由于網(wǎng)絡安全威脅的...詳情>>

2023-12-24 16:16:28
Golang編碼規(guī)范提高代碼質(zhì)量與可維護性

Golang編碼規(guī)范:提高代碼質(zhì)量與可維護性在 Golang 編程中,編碼規(guī)范是非常重要的。它能夠幫助開發(fā)人員提高代碼的質(zhì)量和可維護性。本篇文章將介...詳情>>

2023-12-24 16:09:26
Golang編程實戰(zhàn)從零到一構(gòu)建分布式系統(tǒng)

Golang編程實戰(zhàn):從零到一構(gòu)建分布式系統(tǒng)分布式系統(tǒng)是當今大數(shù)據(jù)、云計算和物聯(lián)網(wǎng)時代的必備技術之一,而Golang作為一種高效、簡潔、并發(fā)能力強...詳情>>

2023-12-24 16:07:40