<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    so true

    心懷未來(lái),開(kāi)創(chuàng)未來(lái)!
    隨筆 - 160, 文章 - 0, 評(píng)論 - 40, 引用 - 0
    數(shù)據(jù)加載中……

    read-write lock

    (一)當(dāng)前被讀鎖占著
        1。如果讀優(yōu)先(默認(rèn)是PTHREAD_RWLOCK_PREFER_READER_NP,即讀優(yōu)先),那么等著的讀請(qǐng)求可以快速拿到鎖,寫(xiě)一直被餓著(直到?jīng)]有任何等待獲取讀鎖的情況下,寫(xiě)才能拿到寫(xiě)鎖);
        2。如果寫(xiě)優(yōu)先,那么讀和寫(xiě)都等著,一但前面的讀釋放了鎖,寫(xiě)立刻就會(huì)優(yōu)先讀來(lái)拿到鎖;
    (二)當(dāng)前被寫(xiě)鎖占著
        不論誰(shuí)優(yōu)先,都需要把所有等著的寫(xiě)都服務(wù)完,才會(huì)給讀機(jī)會(huì),所以寫(xiě)多讀少的情況下,就應(yīng)該用互斥鎖了;

    測(cè)試程序:
    #include <iostream>
    #include <string>
    #include <fstream>
    #include <sstream>
    #include <stdint.h>
    #include <pthread.h>
    #include <vector>
    #include <map>
    #include <set>
    using namespace std;
    long g_idx = 0;
    class ThreadRwLock {
    private:
        pthread_rwlock_t m_rw_mutex;
    public:
        ThreadRwLock() {
            pthread_rwlockattr_t attr;
            // 設(shè)置寫(xiě)優(yōu)先
            pthread_rwlockattr_init(&attr);
            //pthread_rwlockattr_setkind_np(&attr, PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP);
            pthread_rwlock_init(&m_rw_mutex, &attr);
        }
        ~ThreadRwLock() {
            pthread_rwlock_destroy(&m_rw_mutex);
        }
        void rdlock() {
            pthread_rwlock_rdlock(&m_rw_mutex);
        }
        void wrlock() {
            pthread_rwlock_wrlock(&m_rw_mutex);
        }
        int tryrdlock() {
            return pthread_rwlock_tryrdlock(&m_rw_mutex);
        }
        int trywrlock() {
            return pthread_rwlock_trywrlock(&m_rw_mutex);
        }
        void unlock() {
            pthread_rwlock_unlock(&m_rw_mutex);
        }
    };
    ThreadRwLock g_lock;
    void* thread_routine(void* arg) {
        long is_write = (long)arg;
        if (is_write) {
            printf("%lu wait write lock\n", pthread_self()); fflush(stdout);
            g_lock.wrlock();
            long idx = __sync_add_and_fetch(&g_idx, 1);
            printf("%lu get write lock, %ld\n", pthread_self(), idx); fflush(stdout);
            sleep(5);
            g_lock.unlock();
        } else {
            printf("%lu wait read lock\n", pthread_self()); fflush(stdout);
            g_lock.rdlock();
            long idx = __sync_add_and_fetch(&g_idx, 1);
            printf("%lu get read lock, %ld\n", pthread_self(), idx); fflush(stdout);
            sleep(5);
            g_lock.unlock();
        }
        return NULL;
    }
    int main(int argc, char* argv[]) {
        pthread_t tid = 0;
        pthread_create(&tid, NULL, thread_routine, (void*)0);
        pthread_create(&tid, NULL, thread_routine, (void*)0);
        pthread_create(&tid, NULL, thread_routine, (void*)0);
        pthread_create(&tid, NULL, thread_routine, (void*)0);
        pthread_create(&tid, NULL, thread_routine, (void*)0);
        pthread_create(&tid, NULL, thread_routine, (void*)1);
        getchar(); //讓程序暫停,等待鍵盤敲入一個(gè)字節(jié)后,接著走
        pthread_create(&tid, NULL, thread_routine, (void*)1);
        sleep(2); //確保寫(xiě)鎖被優(yōu)先拿到
        pthread_create(&tid, NULL, thread_routine, (void*)0);
        pthread_create(&tid, NULL, thread_routine, (void*)0);
        pthread_create(&tid, NULL, thread_routine, (void*)1);
        pthread_create(&tid, NULL, thread_routine, (void*)1);
        pthread_create(&tid, NULL, thread_routine, (void*)1);
        pthread_create(&tid, NULL, thread_routine, (void*)1);
        pthread_create(&tid, NULL, thread_routine, (void*)1);
        pthread_create(&tid, NULL, thread_routine, (void*)0);
        pthread_create(&tid, NULL, thread_routine, (void*)0);
        pthread_create(&tid, NULL, thread_routine, (void*)1);
        pthread_create(&tid, NULL, thread_routine, (void*)1);
        pthread_create(&tid, NULL, thread_routine, (void*)1);
        pthread_create(&tid, NULL, thread_routine, (void*)1);
        pthread_create(&tid, NULL, thread_routine, (void*)1);
        pthread_create(&tid, NULL, thread_routine, (void*)1);
        pthread_create(&tid, NULL, thread_routine, (void*)1);
        pthread_create(&tid, NULL, thread_routine, (void*)1);
        pthread_create(&tid, NULL, thread_routine, (void*)1);
        pthread_create(&tid, NULL, thread_routine, (void*)1);
        pthread_create(&tid, NULL, thread_routine, (void*)0);
        pthread_create(&tid, NULL, thread_routine, (void*)0);
        getchar();
        return 0;
    }

    posted on 2018-05-14 12:07 so true 閱讀(213) 評(píng)論(0)  編輯  收藏 所屬分類: C&C++Linux

    主站蜘蛛池模板: 亚洲精品亚洲人成在线麻豆| 国产免费黄色无码视频| 亚洲成色在线综合网站| 男女交性永久免费视频播放| 99久久久国产精品免费牛牛| 国产福利免费视频| 亚洲精品无AMM毛片| 久久亚洲美女精品国产精品| 国产亚洲精午夜久久久久久| 成人人观看的免费毛片| 国产h肉在线视频免费观看| 中文字幕成人免费高清在线视频 | 十八禁的黄污污免费网站| 亚洲天堂男人影院| 亚洲性色成人av天堂| 亚洲va无码va在线va天堂| 亚洲视频人成在线播放| 成年女人永久免费观看片| 台湾一级毛片永久免费| 91久久精品国产免费一区| 13小箩利洗澡无码视频网站免费 | 日本一道一区二区免费看| 1024免费福利永久观看网站| 99久久精品免费精品国产| 嫩草在线视频www免费观看 | 亚洲AⅤ优女AV综合久久久| 四虎在线视频免费观看| 最近中文字幕无免费视频| 永久免费毛片在线播放| 999在线视频精品免费播放观看| 久久久久久国产精品免费无码 | 亚洲精品成人区在线观看| 国产一级大片免费看| 国产一区二区三区在线免费观看 | 亚洲美女精品视频| 亚洲第一香蕉视频| 亚洲的天堂av无码| 91丁香亚洲综合社区| 天堂亚洲国产中文在线| 亚洲人成欧美中文字幕| 无码亚洲成a人在线观看|