類模版std::function是一種通用、多型的函式封裝,std::function的實體可以對任何可以呼叫的目標物體進行存盤、復制、和呼叫操作,這些目標物體包括普通函式、Lambda運算式、函式指標、以及其它函式物件等,std::function物件是對C++中現有的可呼叫物體的一種型別安全的包裹(我們知道像函式指標這類可呼叫物體,是型別不安全的),
通常std::function是一個函式物件類,它包裝其它任意的函式物件,被包裝的函式物件具有型別為T1, …,TN的N個引數,并且回傳一個可轉換到R型別的值,std::function使用 模板轉換建構式接收被包裝的函式物件;特別是,閉包型別可以隱式地轉換為std::function
自己實作function
#include <iostream>
#include <string>
using namespace std;
template<typename T>
class MyFunction3 {
};
template<typename Ty, typename A1>
class MyFunction3<Ty(A1)> {
public:
typedef Ty(*pFunction)(A1);//定義一個函式指標,指標指向的函式回傳型別是Ty,有1個函式引數
MyFunction3<Ty(A1)>(pFunction _pFunction) : _function(_pFunction) {
}
Ty operator()(A1 arg1) {
return (*_function)(arg1);
}
private:
pFunction _function;
};
template<typename Ty,typename A1,typename A2>
class MyFunction3<Ty(A1,A2)> {
public:
typedef Ty(*pFunction)(A1, A2);//定義一個函式指標,指標指向的函式回傳型別是Ty,有兩個函式引數
MyFunction3<Ty(A1, A2)>(pFunction _pFunction):_function(_pFunction) {
}
Ty operator()(A1 arg1, A2 arg2) {
return (*_function)(arg1, arg2);
}
private:
pFunction _function;
};
void showMes(string mes) {
cout << "showMes(string mes)=" << mes << endl;
}
int sum1(int x, int y) {
cout << "sum1 "<<(x+y) << endl;
return x + y;
}
int sum2(int x, int y) {
cout << "sum2 " << (x + y) << endl;
return x + y;
}
int main() {
MyFunction3<int(int, int)> f1(sum1);
f1(20,30);
MyFunction3<void(string)> f2(showMes);
f2("AAAA");
system("pause");
return 0;
}
上面代碼我們實作了兩個模板的部分特例化
class MyFunction3<Ty(A1)> 一個函式引數的
class MyFunction3<Ty(A1,A2)> 兩個函式引數的
所以問題來了...三個引數,四個引數,五個引數等若干個引數的怎么辦?
可以使用C++11 可變引數型別, 具體如下
#include <iostream>
#include <string>
using namespace std;
template<typename T>
class MyFunction4 {
};
template<typename R , typename... A >
class MyFunction4<R(A...)> {
public:
typedef R(*PFUNCTION)(A...);
MyFunction4<R(A...)>(PFUNCTION _p) : function(_p) {}
R operator()(A... arg) {
return (*function)(arg...);
}
private:
PFUNCTION function;
};
void showMes1(string mes) {
cout << "showMes(string mes)=" << mes << endl;
}
int sum11(int x, int y) {
cout << "sum11 " << (x + y) << endl;
return x + y;
}
int sum21(int x, int y) {
cout << "sum21 " << (x + y) << endl;
return x + y;
}
int main() {
MyFunction4<int(int, int)> f1(sum11);
f1(20, 30);
MyFunction4<void(string)> f2(showMes1);
f2("AAAA");
system("pause");
return 0;
}
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/539496.html
標籤:其他
上一篇:Listener記憶體馬
下一篇:每日演算法之二叉搜索樹與雙向鏈表
