青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

大城小魔

天下難事,必作于易;天下大事,必作于細(xì)

  C++博客 ::  :: 聯(lián)系 :: 聚合  :: 管理

公告


最新評(píng)論

Sigslot 是一個(gè)小巧,卻十分易用的開源C++信號(hào)插槽庫。如果不想使用boost的signals庫,Sigslot也不失為一個(gè)不錯(cuò)的選擇,作者是Sarah Thompson,你可以通過sarah@telergy.com與他取得聯(lián)系,相關(guān)文檔在 http://sigslot.sourceforge.net/

 
  關(guān)于Sigslot的使用方法本文不再贅述,它的簡(jiǎn)單易用就已無需要太多的說明。在此對(duì)其代碼結(jié)構(gòu)進(jìn)行一下大體的分析總結(jié)。
首先看下代碼注釋中 Quick documentation的簡(jiǎn)單描述:
 
【SIGSLOT_PURE_ISO】:
   強(qiáng)制設(shè)定其為ISO C++編譯器,并關(guān)閉所有的操作系統(tǒng)提供的線程安全的支持。
【SIGSLOT_USE_POSIX_THREADS】:
   當(dāng)使用gcc以外的編譯器,而編譯器支持Posix線程時(shí),強(qiáng)制使用Posix線程支持。
   (gcc時(shí)該項(xiàng)是默認(rèn)開啟的,如果需要可以使用SIG_PURE_ISO關(guān)閉該項(xiàng))
【SIGSLOT_DEFAULT_MT_POLICY】:
   當(dāng)啟用多線程支持時(shí),默認(rèn)項(xiàng)為全局多線程(multi_threaded_global)。否則默認(rèn)項(xiàng)為單線程
   (single_threaded)。如果想更改默認(rèn),你需要自己定義該項(xiàng)。在純ISO模式中,single_threaded以外的
   內(nèi)容都會(huì)觸發(fā)編譯錯(cuò)誤。
 
 關(guān)于操作系統(tǒng)的說明:
   Win32:
     Win32系統(tǒng)中,必須定義WIN32宏。大多數(shù)主流的編譯器會(huì)默認(rèn)定義該宏,但是你當(dāng)你的編譯環(huán)境并不是很
     標(biāo)準(zhǔn)的時(shí)候,必須有你自己定義。以便于Win32線程支持部分被編譯并自動(dòng)啟動(dòng)。
 
   Unix/Linux/BSD,etc:
     如果你正在使用gcc,則默認(rèn)Posix線程是可用的,所以會(huì)自動(dòng)使用Posix線程部分代碼。使用   
     SIGLOT_PURE_ISO可以關(guān)閉這個(gè)默認(rèn)項(xiàng)(在Windows中)。如果你gcc以外的編譯器,但是仍然想使用    Posix線程部分的代碼,
     你必須#define SIGSLOT_USE_POSIX_THREADS

   ISO C++:
      如果處于不支持多線程的操作系中,或者定義了SIGSLOT_PURE_ISO宏時(shí),所有多線程支持就被關(guān)閉,連
      同可能在會(huì)純ISO C++環(huán)境中會(huì)引發(fā)任何編譯器警告的代碼也不會(huì)被使用。我會(huì)在你提出疑問前,直接告訴
      你gcc -ansi  -pedantic選項(xiàng)不會(huì)成功編譯,但是gcc -ansi沒有問題。Pedantic選項(xiàng)似乎會(huì)引發(fā)大量的
      奇怪錯(cuò)誤。如果你想研究這個(gè)問題,請(qǐng)聯(lián)系作者。
 
 關(guān)于線程模型:
   single_threaded:
      由于signal/slot的使用方式,程序設(shè)定為了單線程模型(例如所有的信號(hào)對(duì)象和槽對(duì)象都是有一個(gè)單線程
      創(chuàng)建和銷毀的)沒有定義相關(guān)保證對(duì)象銷毀一致性的行為(例如:會(huì)得到對(duì)已銷毀對(duì)象使用的錯(cuò)誤或者觸發(fā)內(nèi)存異常)
  
   multi_threaded_global:
      程序設(shè)定多線程模型。使用信號(hào)和插槽的對(duì)象能夠被任一線程安全的創(chuàng)建和銷毀,甚至發(fā)生在信號(hào)和插槽的
      連接已經(jīng)建立的情況中。multi_threaded_global模型,依靠唯一的全局的互斥體實(shí)現(xiàn)線程安全(實(shí)際上
      windows中是使用臨界區(qū)因?yàn)樾阅芨茫T撃P褪褂蒙倭康南到y(tǒng)資源,但是導(dǎo)致更多產(chǎn)生資源競(jìng)爭(zhēng)的機(jī)
      會(huì),或許,因此產(chǎn)生更多的設(shè)備上下文切換是無法避免的。
  
   multi_threaded_local:
      該模型的機(jī)制本質(zhì)上跟multi_threaded_global是沒有太大區(qū)別的,除了各個(gè)信號(hào)和對(duì)象都各自繼承自
      has_slots,他們都具備各自的互斥體/臨界區(qū)部分。實(shí)際上,這意味著互斥體沖突的狀況(因此產(chǎn)生的設(shè)備
     上下文
切換)只會(huì)在最必要的時(shí)候才會(huì)發(fā)生。無論如何在某些操作系統(tǒng)中,創(chuàng)建大量的互斥體會(huì)減慢整個(gè)操
     作系統(tǒng)的運(yùn)行速度,所以使用該模型最好謹(jǐn)而為之。


#if defined(SIGSLOT_PURE_ISO) || (!defined(WIN32) && !defined(__GNUG__) && !defined(SIGSLOT_USE_POSIX_THREADS))
# define _SIGSLOT_SINGLE_THREADED
//單線程模型
#elif defined(WIN32)
# define _SIGSLOT_HAS_WIN32_THREADS
//WIN32多線程模型
# include <windows.h>
#elif defined(__GNUG__) || defined(SIGSLOT_USE_POSIX_THREADS)
# define _SIGSLOT_HAS_POSIX_THREADS
//POSIX多線程模型
# include <pthread.h>
#else
# define _SIGSLOT_SINGLE_THREADED
//單線程模型
#endif

#ifndef SIGSLOT_DEFAULT_MT_POLICY
//默認(rèn)多線程模型策略
# ifdef _SIGSLOT_SINGLE_THREADED //如果強(qiáng)制指定為單線程模型則默認(rèn)策略為單線程
# define SIGSLOT_DEFAULT_MT_POLICY single_threaded
#
else
# define SIGSLOT_DEFAULT_MT_POLICY multi_threaded_local
//否則默認(rèn)策略為local多線程模型
# endif
#endif


對(duì)于單線程模型single_threaded,lock(),unlock()保留為空函數(shù)。
多線程模型中 針對(duì)_SIGSLOT_HAS_WIN32_THREADS和_SIGSLOT_HAS_POSIX_THREAD 開關(guān),對(duì)應(yīng)了Win32和Posix兩個(gè)系統(tǒng)平臺(tái),因?yàn)椴煌脚_(tái)使用不同的線程同步對(duì)象,所以分別實(shí)現(xiàn)兩類平臺(tái)下的兩種 multi_threaded_global、multi_threaded_local版本。在Posix中使用了pthread_mutex_t作為線程同步對(duì)象,Win32中使用CRITICAL_SECTION作為線程同步對(duì)象。

我們可以看到在所有的模板類中都有一個(gè)mt_policy模板參數(shù),有意思的是
template<class mt_policy = SIGSLOT_DEFAULT_MT_POLICY>這并不是多此一舉,若將mt_policy直接替換為SIGSLOT_DEFAULT_MT_POLICY,不僅代碼變得凌亂丑陋,代碼而且維護(hù)性也會(huì)大大降低。

鎖對(duì)象:
lock_block模板類,最終根據(jù)實(shí)例化的模板類使用相應(yīng)的線程模型和同步對(duì)象,只需要將該類實(shí)例化到需要的位置即實(shí)現(xiàn)了線程同步功能,這是比較規(guī)范并簡(jiǎn)單有效的方法。
template<class mt_policy>
class lock_block
{
public:
mt_policy
*m_mutex;

lock_block(mt_policy
*mtx) : m_mutex(mtx)
{
m_mutex
->lock();
}
~lock_block()
{
m_mutex
->unlock();
}
};

 


mt_policy被指定為SIGSLOT_DEFAULT_MT_POLICY宏,同時(shí)也作為一個(gè)強(qiáng)制指定為單線程模型的開關(guān)。

連接對(duì)象 _connection0 ... _connection8:

_connection0<dest_type,mt_policy>
...
_connection8<dest_type,arg1_type...arg8_type,mt_policy>

是接口:
_connection_base0<mt_policy> ...
_connection_base8<arg1_type,...arg8_type,mt_policy>的實(shí)現(xiàn)類,其中:

clone():
使用默認(rèn)拷貝構(gòu)造函數(shù)返回一個(gè)新的_connection_baseN對(duì)象指針。

duplicate(sigslot::has_slots<mt_policy> *pnewdest):
返回一個(gè)新的目標(biāo)對(duì)象為pnewdest的_connection_baseN對(duì)象指針。

emit(arg0_type a0..argN_type aN):
觸發(fā)_connection_baseN中目標(biāo)對(duì)象中指定的函數(shù)指針。

getdest(void)const:
返回目標(biāo)對(duì)象指針。

插槽has_slots<mt_policy>

has_slots<mt_policy>為所有具備插槽對(duì)象的基類,也就是說,任何想接收信號(hào),并將信號(hào)連接到處理函數(shù)(插槽)的對(duì)象都必須繼承自has_slots類。

private:
typedef typename std::
set<_signal_base<mt_policy> *> sender_set;
typedef typename sender_set::const_iterator const_iterator;
sender_set m_senders;


senders 為 _signal_base<mt_policy> 接口指針容器,用于維護(hù)一系列signal0..signal8實(shí)例。

signal_disconnectsignal_connect成員函數(shù)用于管理_signal_base<mt_policy>指針列表m_senders的插入與刪除(最終由信號(hào)對(duì)象signalN的
connect(desttyp *pclass,void(desttype::*pmemfun)() 函數(shù)直接使用。)。實(shí)際上即使對(duì)信號(hào)與插槽的維護(hù)。


信號(hào)對(duì)象 Signal0 ... Signal8 :

以帶一個(gè)參數(shù)的信號(hào)對(duì)象為例:signal1<arg1_type,mt_policy>emit(arg1_type a1) 與 重載運(yùn)算符operator ()(arg1_type a1)功能是一致的。都是遍歷父類成員m_connected_slots中的_connection_base1<arg1_type, mt_policy>指針元素,逐一的調(diào)用_connection_base1中的emit(a1)函數(shù)最終使目標(biāo)函數(shù)被調(diào)用。

函數(shù)connect()生成模板參數(shù)的目標(biāo)對(duì)象和目標(biāo)函數(shù)指針,并將該新連接加入到已連接的列表m_connected_slots中。最后使用has_slots的signal_connect函數(shù),將signal1信號(hào)對(duì)象加入到has_slots的m_senders列表中。代碼如下:

template<class desttype>
void connect(desttype* pclass, void (desttype::*pmemfun)(arg1_type))
{
lock_block
<mt_policy> lock(this);
_connection1
<desttype, arg1_type, mt_policy>* conn =
new _connection1<desttype, arg1_type, mt_policy>(pclass, pmemfun);
m_connected_slots.push_back(conn);
pclass
->signal_connect(this);
}


posted on 2008-11-13 23:43 momor 閱讀(2475) 評(píng)論(2)  編輯 收藏 引用 所屬分類: C++/C

Feedback

# re: 三言兩語Sigslot 2008-11-14 10:48 zuhd
作者能解釋下信號(hào)槽有什么用嗎?  回復(fù)  更多評(píng)論
  

# re: 三言兩語Sigslot 2008-11-14 11:24 momor
大概我確實(shí)應(yīng)該先簡(jiǎn)單介紹下Sigslot比較好 ^^
它與QT的'signal-slot'機(jī)制類似主要是利用類模板技術(shù)和回調(diào)函數(shù),來簡(jiǎn)化類之間通訊的一種方式,無需過多的深入類的細(xì)節(jié),實(shí)際上它類似觀察者模式,簡(jiǎn)單的向signal信號(hào)注冊(cè)你的slot插槽(即是回調(diào)函數(shù),你對(duì)注冊(cè)過信號(hào)的相應(yīng)函數(shù)),當(dāng)信號(hào)被觸發(fā)時(shí),注冊(cè)的插槽便會(huì)被自動(dòng)調(diào)用,這個(gè)機(jī)制對(duì)于實(shí)現(xiàn)插件模式的編程及其便利。
  回復(fù)  更多評(píng)論
  


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲精品视频在线看| 91久久精品国产91性色tv| 亚洲女人天堂av| 免费日韩成人| 亚洲中无吗在线| 欧美激情一区二区三区成人| 久久久久国产成人精品亚洲午夜| 亚洲毛片视频| 欧美+亚洲+精品+三区| 韩国av一区二区| 欧美一区影院| 亚洲私人影吧| 欧美亚一区二区| 一区二区三区四区国产精品| 亚洲激情亚洲| 欧美精品国产| 亚洲图片你懂的| 99精品99| 国产精品久久久久久影视 | 老司机免费视频一区二区| 国产女精品视频网站免费| 亚洲欧美综合v| 亚洲综合色自拍一区| 国产欧美成人| 久久欧美肥婆一二区| 久久精品国产免费| 伊人成年综合电影网| 欧美刺激性大交免费视频| 蜜桃久久av| 99re66热这里只有精品3直播| 亚洲大胆女人| 欧美精品一级| 亚洲一区二区三区精品动漫| 亚洲在线视频免费观看| 国产亚洲精品自拍| 欧美成人午夜77777| 欧美精品v国产精品v日韩精品| 亚洲午夜精品久久久久久app| 亚洲天堂男人| 一区二区三区在线高清| 欧美激情在线有限公司| 欧美日韩一区二区在线观看| 翔田千里一区二区| 久久久久久亚洲精品杨幂换脸| 亚洲国产乱码最新视频| 一本色道久久综合狠狠躁篇怎么玩 | 亚洲免费视频观看| 极品少妇一区二区| 日韩视频第一页| 国产三级欧美三级| 91久久线看在观草草青青| 国产精品私房写真福利视频| 欧美1区免费| 国产精品高潮呻吟久久| 美国三级日本三级久久99| 欧美日韩一区二区在线视频 | 正在播放日韩| 国产精品免费观看在线| 老牛国产精品一区的观看方式| 欧美高清视频一区二区三区在线观看| 亚洲视频一区二区| 久久全球大尺度高清视频| 亚洲深夜福利视频| 久久综合伊人77777| 欧美一区二区福利在线| 欧美精品一区二区蜜臀亚洲| 久久久www成人免费毛片麻豆| 欧美激情无毛| 你懂的一区二区| 国产日韩欧美中文| 制服丝袜亚洲播放| 亚洲理论电影网| 久久人人爽爽爽人久久久| 性视频1819p久久| 欧美日韩国产一区二区三区地区| 免费观看成人| 韩国一区电影| 欧美一级视频| 午夜欧美精品| 欧美午夜精品久久久久免费视 | 女仆av观看一区| 久久综合国产精品| 国产一区亚洲| 午夜精品久久久久久久久久久久久 | 一区二区三区国产精华| 免费成人网www| 欧美成人高清视频| 伊人精品在线| 久久久成人精品| 久久婷婷亚洲| 黄色免费成人| 久久美女性网| 欧美成人午夜视频| 亚洲黄色一区二区三区| 久久亚洲精品一区二区| 久久综合一区| 精品成人国产在线观看男人呻吟| 香蕉久久夜色精品国产| 久久久国产视频91| 精品88久久久久88久久久| 久久久亚洲一区| 欧美电影免费网站| 日韩一级免费| 国产精品ⅴa在线观看h| 国产精品99久久99久久久二8| 亚洲欧美另类综合偷拍| 国产视频精品va久久久久久| 久久精品盗摄| 欧美a级片一区| 日韩午夜在线电影| 欧美午夜精品久久久久久孕妇| 亚洲婷婷在线| 久久久亚洲一区| 激情欧美丁香| 亚洲手机视频| 国产精品美女一区二区在线观看| 亚洲免费一在线| 亚洲天堂av电影| 在线亚洲欧美视频| 午夜精品视频一区| 久久久久久久国产| 久久婷婷国产综合尤物精品| 亚洲国产第一页| 一区二区欧美国产| 亚洲综合色婷婷| 欧美伊人久久| 久久精品视频va| 国产乱人伦精品一区二区| 亚洲一区欧美激情| 久久综合色8888| 日韩午夜激情av| 国产日韩精品入口| 欧美不卡视频| 亚洲在线免费观看| 欧美成人69| 亚洲欧美变态国产另类| 国产综合色产| 欧美日韩在线精品一区二区三区| 欧美一区二区精美| 亚洲精品久久久蜜桃| 久久国产精品久久久久久电车| 亚洲电影免费在线观看| 国产精品进线69影院| 久久婷婷蜜乳一本欲蜜臀| 一区二区三区久久精品| 免费永久网站黄欧美| 欧美亚洲免费电影| 亚洲日韩欧美视频| 国内精品免费在线观看| 欧美调教vk| 免播放器亚洲一区| 久久精品亚洲精品| 亚洲综合色噜噜狠狠| 日韩亚洲欧美中文三级| 你懂的视频欧美| 久久国内精品视频| 亚洲性xxxx| 一二美女精品欧洲| 亚洲精品视频啊美女在线直播| 娇妻被交换粗又大又硬视频欧美| 欧美性色视频在线| 欧美日韩国内自拍| 欧美激情精品久久久久久蜜臀 | 欧美在线影院| 亚洲天堂免费在线观看视频| 亚洲精品国产视频| 亚洲大胆女人| 国语自产偷拍精品视频偷| 国产精品亚洲综合色区韩国| 欧美激情在线狂野欧美精品| 久久综合九色欧美综合狠狠| 久久成人18免费观看| 午夜精品影院在线观看| 亚洲欧美另类中文字幕| 亚洲午夜视频| 亚洲天堂成人在线视频| 亚洲深夜激情| 在线成人免费观看| 亚洲第一区色| 国产精品午夜在线观看| 欧美大香线蕉线伊人久久国产精品| 久久天天躁狠狠躁夜夜爽蜜月| 一本色道**综合亚洲精品蜜桃冫| 欧美中文字幕在线观看| 99国产精品久久| 亚洲欧美综合精品久久成人| 亚洲一级一区| 欧美日韩精品系列| 欧美一区综合| 亚洲一区二区三区777| 亚洲剧情一区二区| 亚洲人精品午夜| 亚洲人成网站精品片在线观看| 亚洲国产精品精华液网站| 亚洲国产成人91精品| 亚洲黄色性网站| 99精品视频免费全部在线| 亚洲无玛一区| 欧美中文字幕视频| 欧美jjzz|