C++ 11中的auto和decltype
C++ 11中引入的auto主要有兩種用途:自動類型推斷和返回值占位。auto在C++ 98中的標識臨時變量的語義,由于使用極少且多余,在C++ 11中已被刪除。
auto自動類型推斷,用于從初始化表達式中推斷出變量的數(shù)據(jù)類型。通過auto的自動類型推斷,可以大大簡化我們的編程工作。下面是一些使用auto的例子。
- auto a; // 錯誤,沒有初始化表達式,無法推斷出a的類型
- auto int a = 10 // 錯誤,auto臨時變量的語義在C++ 11中已不存在
- auto a = 10
- auto c = 'A'
- auto s("hello");
- vector<int> vctTemp;
- auto it = vctTemp.begin();
- auto ptr = [](){ cout << "hello world" << endl; };
另外,在使用模板技術(shù)時,如果某個變量的類型依賴于模板參數(shù),不使用auto將很難確定變量的類型(使用auto后,將由編譯器自動進行確定)。下面是一個具體的例子。
- template <class T, class U>
- void Multiply(T t, U u)
- {
- auto v = t*u;
- }
auto返回值占位,主要與decltype配合使用,用于返回值類型后置時的占位。
- template <class T, class U>
- auto Multiply(T t, U u)->decltype(t*u)
- {
- typedef decltype(t*u) NewType;
- NewType *pResult = new NewType(t*u);
- return *pResult;
- }
至于為什么需要將返回值類型后置,這里簡單說明一下。如果沒有后置,則函數(shù)聲明為decltype(t*u) Multiply(T t, U u),但此時模板參數(shù)t和u還未聲明,編譯無法通
過。另外,如果非要使用返回值類型前置的形式,也可以將函數(shù)聲明為decltype((*(T *)0)*(*(U *)0)) Multiply(T t, U u),但這種形式比較晦澀難懂,因此不推薦采用。
原文地址:http://www.cnblogs.com/hujian/archive/2012/02/15/2352050.html
【編輯推薦】