<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

    主站蜘蛛池模板: MM1313亚洲国产精品| 亚洲看片无码在线视频| 精品亚洲国产成AV人片传媒| 亚洲白嫩在线观看| 亚洲色成人四虎在线观看| 美女隐私免费视频看| 国产免费福利体检区久久| 黄网站色视频免费在线观看的a站最新 | 国产jizzjizz免费看jizz| 亚洲人午夜射精精品日韩| 国产精品亚洲片在线| 亚洲一区二区免费视频| 国产亚洲精品成人久久网站 | 婷婷亚洲综合五月天小说在线| 七次郎成人免费线路视频| 久久精品免费观看| 国产v精品成人免费视频400条| 国产精品免费播放| 亚洲国产精华液网站w| 亚洲一区二区三区91| 边摸边吃奶边做爽免费视频网站| 花蝴蝶免费视频在线观看高清版| 久久国内免费视频| 亚洲一级片内射网站在线观看| 亚洲资源在线视频| 免费人成动漫在线播放r18 | 免费一级做a爰片性色毛片| 亚洲成AV人片在线观看ww| 一本天堂ⅴ无码亚洲道久久| a毛片成人免费全部播放| 120秒男女动态视频免费| 可以免费观看的一级毛片| 亚洲高清日韩精品第一区| 亚洲成a∨人片在无码2023 | 91视频国产免费| 中文亚洲成a人片在线观看| 亚洲男人天堂2018av| 特级做A爰片毛片免费看无码| 最近中文字幕免费mv视频8| 亚洲精品无码Av人在线观看国产| 亚洲欧洲专线一区|