C++返回值類型后置實現(xiàn)(跟蹤返回值類型)
在泛型編程中,可能需要通過參數(shù)的運算來得到返回值的類型??紤]下面這個場景:
template <typename R, typename T, typename U> R add(T t, U u) { return t+u; } int a = 1; float b = 2.0; auto c = add<decltype(a + b)>(a, b);
我們并不關心 a+b 的類型是什么,因此,只需要通過 decltype(a+b) 直接得到返回值類型即可。但是像上面這樣使用十分不方便,因為外部其實并不知道參數(shù)之間應該如何運算,只有 add 函數(shù)才知道返回值應當如何推導。
那么,在 add 函數(shù)的定義上能不能直接通過 decltype 拿到返回值呢?
template <typename T, typename U>
decltype(t + u) add(T t, U u) // error: t、u尚未定義
{
return t + u;
}
當然,直接像上面這樣寫是編譯不過的。因為 t、u 在參數(shù)列表中,而 C++ 的返回值是前置語法,在返回值定義的時候參數(shù)變量還不存在。
可行的寫法如下:
template <typename T, typename U> decltype(T() + U()) add(T t, U u) { return t + u; }
考慮到 T、U 可能是沒有無參構(gòu)造函數(shù)的類,正確的寫法應該是這樣:
template <typename T, typename U> decltype((*(T*)0) + (*(U*)0)) add(T t, U u) { return t + u; }
雖然成功地使用 decltype 完成了返回值的推導,但寫法過于晦澀,會大大增加 decltype 在返回值類型推導上的使用難度并降低代碼的可讀性。
因此,在 C++11 中增加了返回類型后置(trailing-return-type,又稱跟蹤返回類型)語法,將 decltype 和 auto 結(jié)合起來完成返回值類型的推導。
返回類型后置語法是通過 auto 和 decltype 結(jié)合起來使用的。上面的 add 函數(shù),使用新的語法可以寫成:
template <typename T, typename U> auto add(T t, U u) -> decltype(t + u) { return t + u; }
為了進一步說明這個語法,再看另一個例子:
int& foo(int& i); float foo(float& f); template <typename T> auto func(T& val) -> decltype(foo(val)) { return foo(val); }
如果說前一個例子中的 add 使用 C++98/03 的返回值寫法還勉強可以完成,那么這個例子對于 C++ 而言就是不可能完成的任務了。
在這個例子中,使用 decltype 結(jié)合返回值后置語法很容易推導出了 foo(val) 可能出現(xiàn)的返回值類型,并將其用到了 func 上。
返回值類型后置語法,是為了解決函數(shù)返回值類型依賴于參數(shù)而導致難以確定返回值類型的問題。有了這種語法以后,對返回值類型的推導就可以用清晰的方式(直接通過參數(shù)做運算)描述出來,而不需要像 C++98/03 那樣使用晦澀難懂的寫法。
到此這篇關于C++返回值類型后置實現(xiàn)(跟蹤返回值類型)的文章就介紹到這了,更多相關C++返回值類型后置實現(xiàn)(跟蹤返回值類型)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
一文掌握C++ const與constexpr及區(qū)別
C++ 11標準中,const 用于為修飾的變量添加“只讀”屬性而 constexpr關鍵字則用于指明其后是一個常量,編譯器在編譯程序時可以順帶將其結(jié)果計算出來,而無需等到程序運行階段,這樣的優(yōu)化極大地提高了程序的執(zhí)行效率,本文重點介紹C++ const與constexpr區(qū)別介紹,一起看看吧2024-02-02