Rumah > pembangunan bahagian belakang > Golang > Apakah Mutex dan Cara Menggunakannya di Golang?

Apakah Mutex dan Cara Menggunakannya di Golang?

Patricia Arquette
Lepaskan: 2024-12-30 15:42:11
asal
712 orang telah melayarinya

Semasa pembangunan LiveAPI, alat penjanaan dokumentasi Auto API, saya perlu melaksanakan mekanisme baris gilir yang teguh yang berskala berdasarkan bilangan teras mesin pelayan. Ini penting untuk mengelakkan penggunaan sumber yang berlebihan (memori dan CPU) yang boleh menyebabkan kebuluran sumber, ranap sistem dan pengalaman pengguna yang buruk.

Dalam artikel ini, saya akan menerangkan cara saya menggunakan mutex di Golang untuk menangani cabaran ini.

Apakah itu Mutex?
Dalam pengaturcaraan serentak, Mutex (Mutual Exclusion) ialah mekanisme penguncian yang menghalang keadaan perlumbaan dengan memastikan hanya satu goroutine boleh mengakses sumber yang dikongsi pada satu masa. Ia serupa dengan kunci bilik – hanya seorang boleh memegang kunci dan masuk sekali gus.

What is Mutex and How to Use it in Golang?

Penggunaan Mutex di Golang
Mari kita gambarkan bagaimana Mutex boleh mengurus pelaksanaan kerja serentak:
Pakej penyegerakan Go menyediakan beberapa primitif untuk penyegerakan, dengan Mutex menjadi salah satu alat yang paling biasa digunakan.

var (
    maxConcurrentJobs int
    activeJobs        int
    jobMutex          sync.Mutex
)
Salin selepas log masuk

Dalam kod ini, pembolehubah activeJobs menjejaki bilangan kerja yang sedang dijalankan. Memandangkan berbilang goroutin mungkin cuba mengubah suai pembolehubah ini secara serentak, yang membawa kepada keadaan perlumbaan, kami menggunakan Mutex untuk menyegerakkan akses.

// Check if we can process more jobs
jobMutex.Lock()
if activeJobs >= maxConcurrentJobs {
    jobMutex.Unlock()
    // Wait before checking again
    time.Sleep(time.Second)
    continue
}
jobMutex.Unlock()
Salin selepas log masuk

Cara Mutex Berfungsi
Mengunci: Kaedah Lock() memperoleh akses eksklusif ke bahagian kritikal.

Membuka Kunci: Kaedah Unlock() melepaskan kunci.

Bahagian Kritikal: Kod antara Kunci dan Buka Kunci tempat **sumber yang dikongsi diakses.

Jenis Mutex di Golang
sync.Mutex: Ini ialah kunci pengecualian bersama asas dalam Go. Ia membenarkan hanya satu goroutine mengakses bahagian kritikal pada satu masa.

type SafeCounter struct {
    mu    sync.Mutex
    count int
}
Salin selepas log masuk

sync.RWMutex: Ini ialah mutex pembaca/penulis yang membenarkan berbilang pembaca mengakses sumber yang dikongsi secara serentak, tetapi hanya seorang penulis pada satu masa.

var rwMutex sync.RWMutex
// Reader methods
rwMutex.RLock()   // Lock for reading
rwMutex.RUnlock() // Unlock for reading

// Writer methods
rwMutex.Lock()    // Lock for writing
rwMutex.Unlock()  // Unlock for writing
Salin selepas log masuk

Mutex ialah alatan penting untuk mengurus sumber kongsi dalam program Go serentak. Mereka menghalang keadaan perlumbaan dan memastikan integriti data dengan mengawal akses kepada bahagian kritikal kod.

Atas ialah kandungan terperinci Apakah Mutex dan Cara Menggunakannya di Golang?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:dev.to
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan