讀書筆記《C++設計新思維》(5) 編譯期間偵測可轉換性
Posted on 2006-02-05 05:34 Tommy Liang 閱讀(781) 評論(2) 編輯 收藏 引用 所屬分類: 泛型編程與設計模式就是這樣一個類:
template <class T,class U>
class Conversion


{
typedef char Small;

class Big
{ char dummy[2]; };
static Small Test(U);
static Big Test(
);
static T MakeT();
public:

enum
{ exists = sizeof(Test(MakeT())) == sizeof(Small) };
};
關于函數 Small Test(U) 和 Big Test(...) ,書里面說:
。。。需要兩個重載函數,其一如先前所說,接受一個U對象并傳回一個Small對象:
Small Test(U);
但接下來,我該如何寫出一個可接受任何其他種對象的函數呢?。。。。
我覺得這個地方翻譯得有點問題,是不是應該說:“。。我該如何寫出一個可接受任何另外一種類型(即 T)的對象的函數呢。。”,因為這里就是 T和U嘛, 沒有什么“其他種”,這樣翻譯容易讓我迷惑不解了一會兒。
如果接受 U的那個函數被調用,則T可以被轉換為 U,否則無法轉換,這個是思路的根本。
為什么要做一個 MakeT這樣的函數而不直接使用T呢? 這是為了滿足當 T 只有私有構造函數的情況,對于編譯器來說,sizeof 是在編譯期完成評估的,所以,MakeT 里面到底做了什么并不重要,重要的是他返回的類型,是 T,所以,作者很興奮地說,這是一個 StrawMan function,即“稻草人函數”,哈哈,只是一個樣子而已,但是這已經足夠了,那兩個重載的Test方法也是一樣,這里我們不關心他的函數體。強啊,爽歪歪,快感的源泉啊
測試代碼如下:
using namespace std;

cout << Conversion<double, int>::exists << ' '
<< Conversion<char, char*>::exists << ' '
<< Conversion<size_t, vector<int> >::exists << ' ';輸出: 1 0 0
double可以轉換為 int
char 不能轉換為 char*
vector<int> 是一個容器的構造函數,size_t 不能轉換,因為這個構造函數是 explicit的,這個地方還是有點迷糊,還得研究一下。
template <class T,class U>
class Conversion

{
typedef char Small;
class Big
{ char dummy[2]; };
static Small Test(U);
static Big Test(
);
static T MakeT();
public:
enum
{ exists = sizeof(Test(MakeT())) == sizeof(Small) };
};關于函數 Small Test(U) 和 Big Test(...) ,書里面說:
。。。需要兩個重載函數,其一如先前所說,接受一個U對象并傳回一個Small對象:
Small Test(U);
但接下來,我該如何寫出一個可接受任何其他種對象的函數呢?。。。。我覺得這個地方翻譯得有點問題,是不是應該說:“。。我該如何寫出一個可接受任何另外一種類型(即 T)的對象的函數呢。。”,因為這里就是 T和U嘛, 沒有什么“其他種”,這樣翻譯容易讓我迷惑不解了一會兒。
如果接受 U的那個函數被調用,則T可以被轉換為 U,否則無法轉換,這個是思路的根本。
為什么要做一個 MakeT這樣的函數而不直接使用T呢? 這是為了滿足當 T 只有私有構造函數的情況,對于編譯器來說,sizeof 是在編譯期完成評估的,所以,MakeT 里面到底做了什么并不重要,重要的是他返回的類型,是 T,所以,作者很興奮地說,這是一個 StrawMan function,即“稻草人函數”,哈哈,只是一個樣子而已,但是這已經足夠了,那兩個重載的Test方法也是一樣,這里我們不關心他的函數體。強啊,爽歪歪,快感的源泉啊
測試代碼如下:
using namespace std;
cout << Conversion<double, int>::exists << ' '
<< Conversion<char, char*>::exists << ' '
<< Conversion<size_t, vector<int> >::exists << ' ';double可以轉換為 int
char 不能轉換為 char*
vector<int> 是一個容器的構造函數,size_t 不能轉換,因為這個構造函數是 explicit的,這個地方還是有點迷糊,還得研究一下。


