自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Go arena 民間庫來了,可以手動管理內(nèi)存!

開發(fā) 前端
今天給大家分享了 Go 官方 arena 的最新進展和情況,主體上還是由于嚴(yán)重 API 原因(擔(dān)憂像 context 一樣造成傳染性)沒有突破性進展。雖然有人提出可以放到 unsafe 庫中,也獲得了許多人表情點贊。但仍然沒能打動 Go 核心團隊的同學(xué)。

大家好,我是煎魚。

上年我們有討論過關(guān)于 Go arena 手動管理內(nèi)存的相關(guān)提案。一開始還高歌猛進,但沒想到后面由于嚴(yán)重的 API 問題(想把 arena 應(yīng)用到其他的標(biāo)準(zhǔn)庫中,但會引入大問題):

圖片圖片

Go 核心團隊中途咕咕咕到現(xiàn)在,沒有新的推動和突破性進展,實屬尷尬。

圖片圖片

最近有社區(qū)的大佬有了新的動作,來自 Grafana 的 @Miguel ángel Ortu?o 開源了一個新的第三方庫 ortuman/nuke[1],用于完成 arena 手動管理內(nèi)存的訴求。

今天我們基于官方資料此進行使用分享和介紹,也好未雨綢繆一下。

溫習(xí)前置知識

Arena 指的是一種從一個連續(xù)的內(nèi)存區(qū)域分配一組內(nèi)存對象的方式。當(dāng)然了,它的重點是要手動管理內(nèi)存,實現(xiàn)一些編程上的內(nèi)存管理目標(biāo)。

優(yōu)點比一般的內(nèi)存分配更有效率,也可以一次性釋放。缺點上需要程序員在編程時手動管理,有可能會泄漏和錯釋放,增大了心智負(fù)擔(dān)。

簡單來講就是,Arena 可以手動管理內(nèi)存,可以做很多事,有利有弊。也 “容易” 崩。

快速介紹

安裝

安裝命令如下:

go get -u github.com/ortuman/nuke

需要注意這個庫要求 go >= 1.21.7,在實際下載前建議先進行升級。

使用案例

常規(guī)使用

基本使用該 arean 庫的用法,代碼如下:

import (
 "github.com/ortuman/nuke"
)

type Foo struct{ A int }

func main() {
 arena := nuke.NewMonotonicArena(256*1024, 80)

 fooRef := nuke.New[Foo](arena "Foo")
 fooSlice := nuke.MakeSlice[Foo](arena, 0, 10 "Foo")

 for i := 0; i < 20; i++ {
  fooSlice = nuke.SliceAppend(arena, fooSlice, Foo{A: i})
 }
 // 做一些煎魚的業(yè)務(wù)邏輯...
    
 arena.Reset(true)
 ...
}
  • 初始化一個新的 arean 內(nèi)存區(qū)域,緩沖區(qū)大小為 256KB,最大內(nèi)存上限為 20MB。
  • 聲明和分配一個 Foo 類型的新對象和容量為 10 個元素的 Foo 切片。
  • 業(yè)務(wù)邏輯完成后,重置所申請的 arean 內(nèi)存區(qū)域(釋放)。

以上是最常用的方式,相當(dāng)于在某一塊代碼片段中進行初始化和處理。

基于 context 場景

如果我們需要在 HTTP 請求這類整個生命周期中去使用。

可以借助 context,使用如下方式:

func httpHandler(w http.ResponseWriter, r *http.Request) {
    arena := nuke.NewMonotonicArena(64*1024, 10)
    defer arena.Reset(true)

    ctx := nuke.InjectContextArena(r.Context(), arena)
    processRequest(ctx)
    // 給煎魚靜悄悄干點什么...
}

func processRequest(ctx context.Context) {
    arena := nuke.ExtractContextArena(ctx)

    // ...
}

func main() {
    http.HandleFunc("/", httpHandler)    fmt.Println("Server is listening on port 8080...")
    http.ListenAndServe(":8080", nil)
}

在請求端 http context 中注入 arena,再在實際處理的地方通過 context 獲取 arena,以此達到穿越整體生命周期的方式。

基于并發(fā)場景

默認(rèn)場景下,nuke.NewMonotonicArena 初始化出來的 arena,有一個隱性的坑,他不是并發(fā)安全的!

大膽猜測,這是基于性能的考慮,所以沒有做到一起。畢竟鎖會很吃資源。而在 Go 里要去做手動內(nèi)存管理的場景,多少又對性能有一定的訴求。

在有并發(fā)訴求的場景下,可以使用 NewConcurrentArena 函數(shù):

import (
 "github.com/ortuman/nuke"
)

func main() {
 arena := nuke.NewConcurrentArena(
            nuke.NewMonotonicArena(256*1024, 20),
        )
 defer arena.Reset(true)
 // 和煎魚煎個魚看看...
}

除了換了個初始化方法,其他用法與常規(guī)用法差不多。

也看了下官方的 Benchmarks,確實是基于性能考慮的區(qū)分并發(fā)與非并發(fā)的業(yè)務(wù)場景。QPS 越大,性能差距越大:

BenchmarkMonotonicArenaNewObject/100-8                    124495      15469 ns/op        0 B/op        0 allocs/op
BenchmarkMonotonicArenaNewObject/1000-8                    76744      19602 ns/op        0 B/op        0 allocs/op
BenchmarkMonotonicArenaNewObject/10000-8                   24104      50845 ns/op        0 B/op        0 allocs/op
BenchmarkMonotonicArenaNewObject/100000-8                   3282     366044 ns/op        0 B/op        0 allocs/op
BenchmarkConcurrentMonotonicArenaNewObject/100-8           90392      16679 ns/op        0 B/op        0 allocs/op
BenchmarkConcurrentMonotonicArenaNewObject/1000-8          43753      29823 ns/op        0 B/op        0 allocs/op
BenchmarkConcurrentMonotonicArenaNewObject/10000-8          8037     149923 ns/op        0 B/op        0 allocs/op
BenchmarkConcurrentMonotonicArenaNewObject/100000-8          879    1364377 ns/op

總結(jié)

今天給大家分享了 Go 官方 arena 的最新進展和情況,主體上還是由于嚴(yán)重 API 原因(擔(dān)憂像 context 一樣造成傳染性)沒有突破性進展。雖然有人提出可以放到 unsafe 庫中,也獲得了許多人表情點贊。但仍然沒能打動 Go 核心團隊的同學(xué)。

基于此,我們介紹了民間大佬的 arena 開源庫 ortuman/nuke?;竟δ芎褪褂枚寄軌驖M足需求。后續(xù)有此類業(yè)務(wù)需求時,可以隨時拿起來就用!

參考資料

[1]ortuman/nuke: https://github.com/ortuman/nuke

責(zé)任編輯:武曉燕 來源: 腦子進煎魚了
相關(guān)推薦

2023-02-26 22:47:45

Go管理內(nèi)存

2024-12-03 08:47:01

2022-11-15 09:16:59

2022-07-20 10:33:50

RustGo內(nèi)存管理

2024-10-22 14:20:00

AI模型

2014-01-14 09:10:53

GoHTTP內(nèi)存泄漏

2023-11-02 10:32:27

GoGORM

2010-01-12 11:52:40

2010-03-05 13:59:16

Linux服務(wù)器內(nèi)存

2021-05-30 19:29:12

內(nèi)存Go語言

2022-10-10 11:37:14

Gomap內(nèi)存

2018-03-09 12:40:41

內(nèi)存降價國產(chǎn)

2023-10-29 17:15:57

2022-05-13 23:46:52

GO編程內(nèi)存

2022-07-25 15:38:59

Go 語言Go 語言編譯器內(nèi)存逃逸

2021-07-06 14:47:30

Go 開發(fā)技術(shù)

2013-10-11 17:32:18

Linux運維內(nèi)存管理

2018-07-23 09:26:08

iOS內(nèi)存優(yōu)化

2017-12-06 08:58:03

AndroidGo系統(tǒng)

2024-01-15 11:12:28

Go內(nèi)存開發(fā)
點贊
收藏

51CTO技術(shù)棧公眾號