Rumah >pembangunan bahagian belakang >C++ >Adakah Baris Berbatasan Liblfds Benar-benar Bebas Kunci?
Jaminan Kemajuan Tanpa Kunci dalam Barisan Penampan Pekeliling
Ikhtisar:
Ramai pengaturcara tersilap percaya bahawa "bebas kunci" hanya merujuk kepada pengaturcaraan serentak tanpa mutex. Walau bagaimanapun, algoritma bebas kunci sebenar memberikan jaminan kemajuan, memastikan bahawa sekurang-kurangnya satu utas boleh membuat kemajuan ke hadapan tanpa mengira tindakan utas lain.
Baris Gilir Liblfds Bounded:
Pelaksanaan baris gilir terhad dalam perpustakaan liblfds kelihatan dipersoalkan dari segi jaminan kemajuan tanpa kunci. Algoritma menyimpan slot untuk menolak, bermakna slot tidak boleh muncul sehingga benang tolak selesai. Kebergantungan ini menimbulkan kebimbangan sama ada baris gilir benar-benar layak sebagai bebas kunci.
Definisi Tanpa Kunci:
Struktur tanpa kunci ialah struktur yang mana mana-mana benang boleh digantung selama-lamanya pada bila-bila masa tanpa menyekat benang lain daripada menggunakan struktur. Mengikut takrifan ini, baris gilir liblfds tidak sepenuhnya bebas kunci. Jika benang menolak digantung, baris gilir memasuki keadaan tidak boleh digunakan, melanggar kontrak baris gilir saiz tetap.
Prestasi lwn. Ketepatan:
Sementara pelaksanaan ini mungkin mempamerkan sifat prestasi yang munasabah, ia tidak mempunyai beberapa sifat ketepatan kritikal bagi struktur yang benar-benar bebas kunci. Kelemahan fungsi utama termasuk:
Kesimpulan:
Pelaksanaan baris gilir terikat liblfds kurang daripada takrifan paling ketat tanpa kunci. Ia memberikan beberapa kelebihan prestasi tetapi tidak mempunyai jaminan fungsi tertentu yang penting untuk memastikan kemajuan dan ketepatan dalam semua senario.
Atas ialah kandungan terperinci Adakah Baris Berbatasan Liblfds Benar-benar Bebas Kunci?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!