溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Go HashMap緩存的細(xì)粒度鎖控制

發(fā)布時間:2024-11-08 21:45:31 來源:億速云 閱讀:78 作者:小樊 欄目:編程語言

在Go中,HashMap并不是線程安全的,因此在多線程環(huán)境下使用時需要額外的同步措施。Go提供了sync.Map類型,它是一個線程安全的map實現(xiàn),但如果你需要更細(xì)粒度的鎖控制,可以使用sync.RWMutex來實現(xiàn)。

下面是一個使用sync.RWMutex實現(xiàn)細(xì)粒度鎖控制的HashMap示例:

package main

import (
	"fmt"
	"sync"
)

type FineGrainedHashMap struct {
	mu    sync.RWMutex
	items map[string]interface{}
}

func NewFineGrainedHashMap() *FineGrainedHashMap {
	return &FineGrainedHashMap{
		items: make(map[string]interface{}),
	}
}

func (f *FineGrainedHashMap) Set(key string, value interface{}) {
	f.mu.Lock()
	defer f.mu.Unlock()
	f.items[key] = value
}

func (f *FineGrainedHashMap) Get(key string) (interface{}, bool) {
	f.mu.RLock()
	defer f.mu.RUnlock()
	value, ok := f.items[key]
	return value, ok
}

func (f *FineGrainedHashMap) Delete(key string) {
	f.mu.Lock()
	defer f.mu.Unlock()
	delete(f.items, key)
}

func main() {
	hashMap := NewFineGrainedHashMap()

	// 寫入數(shù)據(jù)
	hashMap.Set("key1", "value1")
	hashMap.Set("key2", "value2")

	// 讀取數(shù)據(jù)
	value, ok := hashMap.Get("key1")
	if ok {
		fmt.Println("key1:", value)
	}

	// 刪除數(shù)據(jù)
	hashMap.Delete("key1")

	// 再次讀取數(shù)據(jù)
	value, ok = hashMap.Get("key1")
	if !ok {
		fmt.Println("key1 not found")
	}
}

在這個示例中,我們定義了一個FineGrainedHashMap結(jié)構(gòu)體,它包含一個sync.RWMutex類型的字段mu和一個map[string]interface{}類型的字段items。我們實現(xiàn)了SetGetDelete方法,這些方法分別用于設(shè)置、獲取和刪除map中的數(shù)據(jù)。在這些方法中,我們使用mu來保護對items的訪問,以實現(xiàn)細(xì)粒度的鎖控制。

當(dāng)多個goroutine同時訪問FineGrainedHashMap時,sync.RWMutex會根據(jù)讀寫操作的不同自動加鎖和解鎖,從而實現(xiàn)高效的并發(fā)訪問。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

go
AI