c++奇淫技巧之完美轉(zhuǎn)發(fā)

解決什么問題

在介紹完美轉(zhuǎn)發(fā)之前,我們先來看下面的一段代碼。


void foo(const shape&)
{
  puts("foo(const shape&)");
}

void foo(shape&&)
{
  puts("foo(shape&&)");
}

void bar(const shape& s)
{
  puts("bar(const shape&)");
  foo(s);
}

void bar(shape&& s)
{
  puts("bar(shape&&)");
  foo(s);
}

int main()
{
  bar(circle());
}

我們猜下,上面會(huì)輸出什么。
===============================留你思考=================================

circle()會(huì)生成一個(gè)右值,所以會(huì)調(diào)用bar(shape&&),這個(gè)時(shí)候參數(shù)s變?yōu)榱俗笾?,所以?huì)調(diào)用foo(const shape&),所以以上的輸出是:

bar(shape&&)
foo(const shape&)

如果我們希望保持bar函數(shù)收到的右值引用,我們就要變?yōu)橄旅娴恼{(diào)用方式:

void bar(shape&& s)
{
  puts("bar(shape&&)");
  foo(std::move(s));
}

可以看到了,bar函數(shù)為了保證在轉(zhuǎn)發(fā)參數(shù)的過程中,保持參數(shù)的值類別:左值的仍然是左值,右值的仍然是右值,不得不重載兩個(gè)bar函數(shù),那有什么簡單的方法能夠?qū)崿F(xiàn)呢?

這就有了c++標(biāo)準(zhǔn)庫中的std::forward,即轉(zhuǎn)發(fā)引用(forwarding reference),也叫做萬能引用(universal reference),具體到實(shí)現(xiàn)上來說就是:

template<typename T>
void bar(T &&s) {
    foo(std::forward<T>(s));
}

此時(shí)再看下面的輸出:

circle temp;
bar(temp);
bar(circle());

大家應(yīng)該能夠很容易回答上來了。

總結(jié)

本文介紹了c++中轉(zhuǎn)發(fā)引用的使用場景:保證在轉(zhuǎn)發(fā)參數(shù)的過程中,保持參數(shù)的值類別:左值的仍然是左值,右值的仍然是右值。

最后一段代碼的輸出,歡迎留言的。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容