• <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>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運轉,開心的工作
            簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            UNIX上C++程序設計守則(6) [轉]

            Posted on 2009-02-03 13:39 S.l.e!ep.¢% 閱讀(324) 評論(1)  編輯 收藏 引用 所屬分類: C++

            UNIX上C++程序設計守則(6)Add star

            準則6: 遵守多線程編程的常識


            1. 要準確把握在POSIX標準的函數中,那些函數是非線程安全的,一定不要使用
            2. 要讓自己編寫的函數符合線程安全
              • 在訪問共享數據/變量之前一定要先鎖定
              • 如果使用C++的話,一定要注意函數的同步方法

            說明: (2) 要讓自己編寫的函數符合線程安全


            在寫多線程的應用程序時,在多個線程里共享的變量要先鎖定然后在更新它.。那么在多線程里共享的變量主要有全局變量和函數內的靜態變量。而且,即使是short型和int型的共享變量也要先鎖定后更新才能保證其安全。


            ※ 詳細的是參考

            還有,在使用C++編程的場合要注意函數的方步方法。一般的說來下面的寫法是錯誤的。Mutex在函數內被聲明成靜態變量是不允許的

            int incr_counter(void) {
            static Mutex m; // 這么寫不行
            m.Lock();

            static int counter = 0;
            int ret = ++counter;

            m.Unlock();
            return ret;
            }

            應該用下面的方式來代替,

            Mutex m;

            int incr_counter(void) {
            m.Lock();
            // ...

            把Mutex聲明成全局變量的話比較好(稍微比上一個好)。


            ※ 詳細是參考

            UNIX上C++程序設計守則(6)-- 補記 Add Star

            線程安全函數是像下面那樣

            1. 不要操作局部的靜態變量(函數內的static型的變量)和非局部的靜態數據(全局變量)。并且,其它的非線程安全函數不要調用
            2. 要操作這樣的變量的話, 就要使用mutex進行同步處理,來限制多個線程同時對它進行操作

            被定義的,但是

            • 特別是前者, 和被叫做可重入的(reentrant)函數有區別
            • 反之, 后者特別是和叫做"Serializable"(不單單是MT-Safe)"Safe"的函數有區別

            也有以上的情況。在Solaris的man手冊里, 用后者的方式進行區別. 從多線程程序里安全調用的話,就叫做"Safe", 而且, 在多線程中能夠并發(concurrency)地執行這個函數的處理的話,好像就叫做"MT-Safe"。

            ?

            嗯, 因為比較詳細的, 如果不是在對于執行速度要求比較苛刻的環境中編寫代碼的話, 單單地意識到「是否線程安全」就足夠了,不是嗎。

            Feedback

            # re: UNIX上C++程序設計守則(6) [轉]  回復  更多評論   

            2009-02-08 22:29 by 放屁阿狗
            為了不談談scopelocker和recursion locker , readwrite lock ,這些才是關鍵的問題
            unix上對于stack有很大的限制
            對打開文件數量也是很有限制的,比如用root來修改這些限制,等等啦
            久久精品成人免费网站| 久久精品国产精品亚洲下载| 免费精品久久天干天干| 色欲综合久久躁天天躁蜜桃| 久久婷婷激情综合色综合俺也去 | 日本福利片国产午夜久久| 久久国产免费直播| 99精品久久精品一区二区| 国产成人综合久久综合| 国产激情久久久久影院老熟女免费| 天天影视色香欲综合久久| 婷婷久久香蕉五月综合加勒比| 久久综合给久久狠狠97色| 狠狠色丁香久久婷婷综合五月| A级毛片无码久久精品免费| 日本久久久久亚洲中字幕| 手机看片久久高清国产日韩| 国产精品一久久香蕉国产线看| 久久久久国产一区二区三区| 国产精品久久久久…| 国产精品久久婷婷六月丁香| 日韩精品国产自在久久现线拍| 伊人久久大香线蕉综合影院首页| 久久国产午夜精品一区二区三区| 国产人久久人人人人爽| 亚洲AV无码久久精品色欲| 亚洲欧洲精品成人久久奇米网| 久久亚洲国产午夜精品理论片| 天天躁日日躁狠狠久久 | 国内精品伊人久久久久妇| 精品国产一区二区三区久久| 久久精品中文字幕无码绿巨人| 中文字幕精品久久久久人妻| 久久国产热这里只有精品| 久久AⅤ人妻少妇嫩草影院| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 久久夜色精品国产亚洲av| 国产综合成人久久大片91| 久久影视国产亚洲| 久久99亚洲综合精品首页| 久久国产美女免费观看精品 |