c++双地址操作符?(,,)

我正在阅读STL源代码,我不知道&&地址操作符应该做什么。下面是来自stl_vector.h的代码示例:

vector&
operator=(vector&& __x) // <-- Note double ampersands here
{
// NB: DR 675.
this->clear();
this->swap(__x);
return *this;
}

“地址的地址”有意义吗?为什么它有两个地址操作符而不是一个?

170597 次浏览

这是c++ 11代码。在c++ 11中,&&令牌可用于表示“右值引用”。

&&是c++ 11中新增的,它表示函数接受RValue-Reference——也就是说,对即将被销毁的实参的引用。

正如其他答案所提到的,在这个上下文中&&令牌对于c++ 0x(下一个c++标准)是新的,并且表示一个“右值引用”。

右值引用是即将到来的标准中更重要的新事物之一;它们支持对象上的“移动”语义,并允许函数调用的完美转发。

这是一个相当复杂的话题——最好的介绍之一(不仅仅是粗略的)是Stephan T. Lavavej的一篇文章,“右值参考:c++ 0x特性在VC10, Part 2”;

请注意,这篇文章仍然是相当繁重的阅读,但非常值得。尽管它是在微软vc++博客上,但所有(或几乎所有)的信息都适用于任何c++ 0x编译器。

我相信这是一个移动操作符。operator=是赋值操作符,比如vector x = vector yclear()函数调用听起来像是在删除向量的内容以防止内存泄漏。运算符返回指向新向量的指针。

这种方式,

std::vector<int> a(100, 10);
std::vector<int> b = a;
for(unsigned int i = 0; i < b.size(); i++)
{
std::cout << b[i] << ' ';
}

即使我们给了向量a值,向量b也有值。这是operator=()的魔力!

MSDN—如何创建一个移动构造函数

&&是c++ 11中的新特性。int&& a表示“a”是一个r值引用。&&通常只用于声明函数的形参。它只有接受一个r值表达式。如果你不知道r值是什么,简单的解释就是它没有内存地址。例如数字6和字符“v”都是r值。int a, a是一个l值,而(a+2)是一个r值。例如:

void foo(int&& a)
{
//Some magical code...
}


int main()
{
int b;
foo(b); //Error. An rValue reference cannot be pointed to a lValue.
foo(5); //Compiles with no error.
foo(b+3); //Compiles with no error.


int&& c = b; //Error. An rValue reference cannot be pointed to a lValue.
int&& d = 5; //Compiles with no error.
}

希望这是有用的。

我相信&&为移动语义。它允许某物放弃自己的记忆给其他需要它的东西,避免复制的需要。

< p >转移构造函数 例如< / p >
String(String&& other) noexcept
{
//...
}