當我們使用函數時習慣于C函數的格式,即如下形式
resulttype funname( arglist );
返回值類型 函數名( 參數列表 );
在Boost.Function中,我們可以方便的定義定義函數對象。不過在定義用來表示類成員函數的函數對象時
第一個參數是類指針。而且在調用時,要傳入一個類實例的指針。這樣用起來并不是很方便,因為調用者
要知道類實例。這實際上沒有實現解耦。而解耦是我們使用回調或委托設計的一個目標。
為了解決這個問題,我們要使用Boost.Bind庫
Boost.Bind是一個函數對象工廠。他用來產生我們需要的函數對象。好了,有了它,你可以在你設計中大
量使用Boost.Function。不用再去定義類成員函數形式的函數對象啦,只用定義普通函數對象。
一個簡單的例子
class CExample
{
public:
bool printstr( const std::string &str )
{
std::cout << "CExample::printstr" << str << std::endl;
return true;
}
};
//定義一個函數對象
boost::function< bool ( const std::string& ) > printstr;
//用Boost.Bind創建一個函數對象,賦給printstr
CExample example;
printstr = boost::bind( &CExample::printstr, &example, _1 );
好了,我們創建了一個函數對象,而且調用時不再需要類實例拉。用Boost.Function和Boost.Bind大大
的簡化了Command模式的實現。
在上面的例子中要個古怪的對象"_1"。這個叫做站位符,他代表這個位置有個參數,但現在還不知道參
數是什么。_1代表參數列表中的第一個位置上的參數。Boost.Bind一共定義了9個站位符對象。如下
_1,_2,_3,_4,_5,_6,_7,_8,_9。分別代表參數列表中位子。
Boost.Bind產生的函數對象可以直接使用,利用上面的例子。
bool b = boost::bind( &CExample::printstr, &example, _1 )( "Hello World" );
posted on 2007-07-20 17:15
walkspeed 閱讀(12855)
評論(3) 編輯 收藏 引用 所屬分類:
STL、Boost、范型編程 、
C++語言