• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆-162  評(píng)論-223  文章-30  trackbacks-0
               自旋鎖作為一種并發(fā)同步的手段,特別適用于競(jìng)爭(zhēng)少和鎖時(shí)間短的情況,在驅(qū)動(dòng)及內(nèi)核代碼中經(jīng)常被用到,本文講述一種適合用戶態(tài)程序的自旋鎖,支持Windows和Linux(GCC>=4.1.2)平臺(tái),并提供了C語(yǔ)言的接口和實(shí)現(xiàn)。

            接口
               spin_trylock如果獲取成功返回1,否則返回0;spin_is_lock如果已加鎖,返回1,否則返回0。
             1typedef struct 
             2{
             3 volatile long  flag_;
             4 volatile long* spin_;
             5}
            spin_lock_t;
             6
             7void spin_init(spin_lock_t* lock,long* flag);
             8
             9void spin_lock(spin_lock_t* lock);
            10
            11int spin_trylock(spin_lock_t* lock);
            12
            13void spin_unlock(spin_lock_t* lock);
            14
            15int spin_is_lock(spin_lock_t* lock);

            實(shí)現(xiàn)
             1#ifdef _MSC_VER
             2#include <windows.h>
             3#elif defined(__GNUC__)
             4#if __GNUC__<4 || (__GNUC__==4 && __GNUC_MINOR__<1)
             5#error GCC version must be greater or equal than 4.1.2
             6#endif
             7#include <sched.h>
             8#else
             9#error Currently only windows and linux os are supported
            10#endif
            11
            12void spin_init(spin_lock_t* lock,long* flag)
            13{
            14#ifdef _MSC_VER
            15    InterlockedExchange((volatile long*)&lock->flag_,0);
            16    InterlockedExchange((volatile long*)&lock->spin_,flag?(long)flag:(long)&lock->flag_);
            17#elif defined(__GNUC__)
            18    __sync_and_and_fetch((long*)&lock->flag_,0);
            19    __sync_lock_test_and_set((long*)&lock->spin_,flag?(long)flag:(long)&lock->flag_);
            20#endif
            21}

            22
            23void spin_lock(spin_lock_t* lock)
            24{
            25#ifdef _MSC_VER
            26    for (;0!=InterlockedExchange((volatile long*)lock->spin_,1);)
            27    {
            28        Sleep(1);
            29    }

            30#elif defined(__GNUC__)
            31    for (;0!=__sync_fetch_and_or(lock->spin_,1);)
            32    {
            33        sched_yield();
            34    }

            35#endif
            36}

            37
            38int spin_trylock(spin_lock_t* lock)
            39{
            40#ifdef _MSC_VER
            41    return !InterlockedExchange((volatile long*)lock->spin_,1);
            42#elif defined(__GNUC__)
            43    return !__sync_fetch_and_or(lock->spin_,1);
            44#endif
            45}

            46
            47void spin_unlock(spin_lock_t* lock)
            48{
            49#ifdef _MSC_VER
            50    InterlockedExchange((volatile long*)lock->spin_,0);
            51#elif defined(__GNUC__)
            52    __sync_and_and_fetch(lock->spin_,0);
            53#endif
            54}

            55
            56int spin_is_lock(spin_lock_t* lock)
            57{
            58#ifdef _MSC_VER
            59    return InterlockedExchangeAdd((volatile long*)lock->spin_,0);
            60#elif defined(__GNUC__)
            61    return __sync_add_and_fetch(lock->spin_,0);
            62#endif
            63}
            posted on 2012-06-13 21:02 春秋十二月 閱讀(3073) 評(píng)論(3)  編輯 收藏 引用 所屬分類: C/C++

            評(píng)論:
            # re: 一種簡(jiǎn)單的跨平臺(tái)用戶態(tài)自旋鎖 2012-06-13 22:57 | egmkang
            lock的時(shí)候,可以先去獲取一下?tīng)顟B(tài),如果都是lock的,那么就沒(méi)有必要原子操作.
            這樣效率會(huì)高一點(diǎn).  回復(fù)  更多評(píng)論
              
            # re: 一種簡(jiǎn)單的跨平臺(tái)用戶態(tài)自旋鎖 2012-06-22 01:34 | tb
            挺不錯(cuò)的   回復(fù)  更多評(píng)論
              
            # re: 一種簡(jiǎn)單的跨平臺(tái)用戶態(tài)自旋鎖 2013-09-25 23:00 | egmkang
            spin_lock的實(shí)現(xiàn),其實(shí)最好的是先判斷一下,然后再去嘗試著原子操作;否則如果鎖碰撞比較大,會(huì)把很多實(shí)踐浪費(fèi)在原子操作上,不劃算.
            另外,把變量聲明成volatile貌似是不合適的吧.多線程和volatile沒(méi)有任何關(guān)系.
            原子操作完成了,其他CPU里面看到的值就一定是最新的,至少在x86體系上面是這樣,如果是其他CPU貌似還要加一個(gè)barrier.  回復(fù)  更多評(píng)論
              
            日本免费一区二区久久人人澡 | 蜜桃麻豆WWW久久囤产精品| 日韩亚洲欧美久久久www综合网 | 国产综合精品久久亚洲| 久久久久青草线蕉综合超碰| 亚洲精品美女久久777777| 国产成人久久激情91| 成人国内精品久久久久影院| 国产免费久久久久久无码| 欧美一区二区久久精品| 精品久久久久久亚洲精品 | 久久亚洲高清综合| 久久精品国产久精国产一老狼| 久久精品国产一区| 欧洲成人午夜精品无码区久久 | 69久久精品无码一区二区| 亚洲国产精品无码久久青草| 国产韩国精品一区二区三区久久| 久久综合九色综合欧美就去吻| 97久久天天综合色天天综合色hd| 久久久噜噜噜久久中文字幕色伊伊| 91久久香蕉国产熟女线看| 99久久99久久久精品齐齐| 久久精品国产亚洲AV蜜臀色欲| 久久99亚洲综合精品首页| 久久免费高清视频| 久久精品国产一区二区三区日韩| 午夜欧美精品久久久久久久| 久久精品成人欧美大片| 国产免费久久久久久无码| 国内精品久久久久影院免费| 久久久久亚洲AV无码永不| 亚洲精品乱码久久久久久按摩| 久久精品国产乱子伦| 亚洲色欲久久久综合网| 久久久久av无码免费网| 一本一道久久a久久精品综合| 亚洲国产成人精品无码久久久久久综合| 国产精品九九久久免费视频| 国产99久久久国产精免费| 人人狠狠综合久久亚洲|