• <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>
            ::^喬喬^::明鏡臺::原創空間::C#.NET2.0,C++技術BLOG
            人最重要的是心境,一顆平靜安穩的心才能更好的進步,保持自己的心態.成為夢想中的高手QQ群:8664695
            posts - 17,comments - 32,trackbacks - 0

            一、基本使用
            頭文件 <boost/thread/thread.hpp>

            namespace ?boost? {
            ??
            class ?thread;
            ??
            class ?thread_group;
            }

            ?

            1、thread
            thread的構造形式為explicit thread(const boost::function0<void>&);
            如果你對boost::function不熟,那么我聽我簡短的介紹一下:
            boost::function0<void>可以簡單看為:一個無返回(返回void),無參數的函數。
            這里的函數也可以是類重載operator()構成的函數。

            舉例來說如下形都可以轉化為function0<void>。

            1 void ?run( void )
            2 {
            3 }

            4
            5 struct ?Run
            6 {
            7 ???? void ? operator ()( void )? {}
            8 }
            ;
            9

            ?

            只要帶參數構造一個thread實例那么就是構建了一個線程,相當的方便快捷。
            于是有了我們第一個例子:
            例一:

            ?1 #include? < boost / thread.hpp >
            ?2 #include? < iostream >
            ?3
            ?4 struct ?Run
            ?5 ???? {
            ?6 ???? void ? operator ()( void )
            ?7 ???????? {
            ?8 ????
            ?9 ????????std::cout << __FUNCTION__ << std::endl;
            10 ????????}

            11 ????}
            ;
            12 void ?run( void )
            13 ???? {
            14 ????std::cout << __FUNCTION__ << std::endl;
            15 ????}

            16
            17 int ?main( int ?argc,? char * ?argv[])
            18 ???? {
            19 ????Run?r;
            20 ????boost::thread?thrd(r);
            21 ????boost::thread?thrdb(run);
            22 ???? return ? 0 ;
            23 ????}

            24
            25

            ?

            運行后發生了什么?線程起動了,但一閃而過,結果都沒能輸出全就運行結束了。

            那該怎么辦呢?
            答:使用thread::join,當join后的thread在該線程未執行結束會一直處于阻塞狀態。

            改下例子中主程序main為

            1 ???? {
            2 ????Run?r;
            3 ????boost::thread?thrd(r);
            4 ????boost::thread?thrdb(run);
            5 ????thrd.join();
            6 ????thrdb.join();
            7 ???? return ? 0 ;
            8 ????}


            看到結果了,但似乎線程有點不同步,呃。。暫時放在一旁吧。
            什么?你覺得void(void)的函數連變量入口都沒,傳值不方便?其實你錯了,當你用會了boost::bind,會發現函數有多少參數都不是問題,都可以輕松bind為void(void)形式。我幾乎可以說boost::thread最基本的的使用就是boost::thread+boost::function+boost::bind的結合。

            2、thread_group
            大家一定注意到除了thread還有thread_group,顧名思義,thread_group就是thread的group,看看main主程序有點煩瑣,引入thread_group看看效果
            先認識下thread_group的成員函數:

            ?

            1 thread * ?create_thread( const ?boost::function0 < void >& );? // 創建一個線程
            2 void ?add_thread(thread * );? // 加入一個已存在的線程
            3 void ?remove_thread(thread * );? // 移除一個線程
            4 void ?join_all();? // 全部等待結束

            ?

            很清晰,改造開始

            1 ???? {
            2 ????Run?r;
            3 ????boost::thread_group?grp;
            4 ????grp.create_thread(r);? // 使用create_thread
            5 ????grp.add_thread( new ?boost::thread(run));? // 使用add_thread
            6 ????grp.join_all();
            7 ???? return ? 0 ;
            8 ????}


            運行,結果完全一樣。

            注意:當thread_group析構時會自動delete已加入的thread

            1 ???? {
            2 ????boost::thread_group?grp;
            3 ????boost::thread * ?thrd = grp.create_thread(r);
            4 ????grp.join_all();
            5 ????delete?thrd;
            6 ????}
            ? // 錯誤,?grp在析構時對已刪除的thrd再進行刪除

            ?

            若要手動管理,可改為:

            1 ???? {
            2 ????Run?r;
            3 ????boost::thread_group?grp;
            4 ????boost::thread * ?thrd = grp.create_thread(r);
            5 ????grp.join_all();
            6 ????grp.remove_thread(thrd);? // 把thrd移出grp
            7 ????delete?thrd;
            8 ???? return ? 0 ;
            9 ????}

            ?

            好了,

            posted on 2009-05-09 19:13 ^喬喬^ 閱讀(1887) 評論(0)  編輯 收藏 引用
            久久久久女人精品毛片| 欧美成人免费观看久久| 久久超乳爆乳中文字幕| 久久精品国产亚洲沈樵| 久久精品国产亚洲AV无码娇色 | 国产99久久久国产精免费| 久久精品国产99国产精品| 精品伊人久久大线蕉色首页| 久久久久成人精品无码中文字幕| 久久国产成人午夜AV影院| 久久国产精品无| 思思久久99热只有频精品66| 精品国际久久久久999波多野| 亚洲国产精品久久久久网站 | 91精品国产高清久久久久久国产嫩草| 精品久久久久中文字| 久久久久亚洲av无码专区导航 | 亚洲精品tv久久久久久久久| 久久久久国产一级毛片高清版| 久久无码高潮喷水| 欧美日韩精品久久久久| 久久国产免费观看精品| 久久久久久夜精品精品免费啦| 亚洲精品国产第一综合99久久| 99久久人人爽亚洲精品美女| 无码精品久久久天天影视| 中文字幕久久精品| 日韩久久无码免费毛片软件| 日本三级久久网| 国产L精品国产亚洲区久久| 国产日产久久高清欧美一区| 久久久精品国产sm调教网站| 久久精品国产日本波多野结衣 | 人人狠狠综合88综合久久| 国产L精品国产亚洲区久久| 久久久九九有精品国产| 日本精品久久久久中文字幕8| 久久99国产乱子伦精品免费| 久久精品国产亚洲AV高清热| 国产成人久久激情91| 国内精品久久九九国产精品|