我buffio.Writer在 GoLang 中使用如下。conn, err := net.Dial("tcp", address) // address is of form ip:portw := bufio.NewWriter(conn)w.WriteByte(code) // code is a bytew.Write(data) // data is a byte bufferw.Flush()我試圖修改上面的代碼,使write()事件有一個(gè)截止日期:當(dāng)截止日期過去時(shí),write()無論成功與否,事件都會(huì)返回。在 GoLang 中,如果conn(連接對(duì)象)直接用于使用conn.SetWriteDeadline(time.Now().Add(n * time.Second)). 但是,當(dāng)我使用bufifo.writer對(duì)象時(shí),它本質(zhì)上是conn緩沖 IO 的包裝器,沒有 API 來設(shè)置截止日期。雖然它可以使用conn.SetWriteDeadline(time.Now().Add(n * time.Second))和使用conn.Write(b),但它非常低效,因?yàn)樗痪彌_write事件(因此有很多上下文切換)在 GoLang 中有沒有一種方法可以將緩沖 IO 與writeDeadline()?
1 回答

慕的地10843
TA貢獻(xiàn)1785條經(jīng)驗(yàn) 獲得超8個(gè)贊
這里有兩種情況需要注意。
如果你想要每個(gè)write()
截止日期,那么就不可能使用緩沖。當(dāng)您使用緩沖時(shí),實(shí)際write()
會(huì)在緩沖區(qū)已滿時(shí)觸發(fā)。所以從技術(shù)上講不可能知道你什么時(shí)候write()
完成。在這種情況下,您實(shí)際上是在使用conn.write()
并且可以使用conn.SetWriteDeadline(time.Now().Add(n * time.Second))
.
在第二種情況下,正如@icza 在評(píng)論中提到的那樣,您可以在底層conn
對(duì)象中設(shè)置截止日期,并且 buffio.writer() 包裝器將遵守此規(guī)則。雖然這在語義上是正確的,但它沒有提供您想要的網(wǎng)絡(luò)抽象。
- 1 回答
- 0 關(guān)注
- 131 瀏覽
添加回答
舉報(bào)
0/150
提交
取消