Penggantian Semaphore C 0x
Walaupun C 0x tidak menyediakan semaphore secara asli, terdapat pendekatan alternatif untuk mencapai penyegerakan antara utas. Satu kaedah ialah menggunakan mutex dan pembolehubah keadaan untuk mencipta semaphore tersuai.
Pertimbangkan coretan kod berikut:
#include <mutex> #include <condition_variable> class semaphore { std::mutex mutex_; std::condition_variable condition_; unsigned long count_ = 0; // Initialized as locked. public: void release() { std::lock_guard<decltype(mutex_)> lock(mutex_); ++count_; condition_.notify_one(); } void acquire() { std::unique_lock<decltype(mutex_)> lock(mutex_); while(!count_) // Handle spurious wake-ups. condition_.wait(lock); --count_; } bool try_acquire() { std::lock_guard<decltype(mutex_)> lock(mutex_); if(count_) { --count_; return true; } return false; } };
Semaphore tersuai ini menyediakan fungsi yang serupa dengan semaphore POSIX, membenarkan urutan untuk menunggu dan melepaskan acara. Kaedah keluaran menambah kiraan dan memberitahu urutan menunggu, manakala kaedah perolehan mengurangkan kiraan dan menunggu jika perlu. Kaedah try_acquire cuba memperoleh semaphore serta-merta tanpa menunggu.
Dengan menggunakan teknik ini, anda boleh mencapai kefungsian seperti semaphore dalam C 0x, walaupun tanpa sokongan semaphore asli.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Melaksanakan Fungsi Semaphore dalam C 0x Tanpa Sokongan Asli?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!