C++ 11 中的右值引用

发布时间:2017-3-28 23:57:39 编辑:www.fx114.net 分享查询网我要评论
本篇文章主要介绍了"C++ 11 中的右值引用 ",主要涉及到C++ 11 中的右值引用 方面的内容,对于C++ 11 中的右值引用 感兴趣的同学可以参考一下。

右值引用的功能

首先,我并不介绍什么是右值引用,而是以一个例子里来介绍一下右值引用的功能:

    #include <iostream>
    #include <vector>
    using namespace std;

    class obj
    {
    public :
        obj() { cout << ">> create obj " << endl; }
        obj(const obj& other) { cout << ">> copy create obj " << endl; }
    };

    vector<obj> foo()
    {
        vector<obj> c;
        c.push_back(obj());

        cout << "---- exit foo ----" << endl;
        return c;
    }

    int main()
    {
        vector<obj> k;
        k = foo();
    }

首先我们编译一下这个函数,运行结果如下:

    tianfang > g++ main.cpp
    tianfang > a.out
    >> create obj 
    >> copy create obj 
    ---- exit foo ----
    >> copy create obj 
    tianfang >

可以看到,对obj对象执行了两次构造。vector是一个常用的容器了,我们可以很容易的分析这这两次拷贝构造的时机:

  1. foo函数第二行,调用push_back的时候,会在vector里建立一个obj的副本
  2. main函数第二行,执行复制函数的时候,会把foo()返回的对象全部复制过来,再次执行一次拷贝构造

由于对象的拷贝构造的开销是非常大的,因此我们想就可能避免他们。其中,第一次拷贝构造是vector的特性所决定的,不可避免。但第二次拷贝构造,在C++ 11中就是可以避免的了。

    tianfang > g++ -std=c++11 main.cpp
    tianfang > a.out
    >> create obj 
    >> copy create obj 
    ---- exit foo ----
    tianfang >

可以看到,我们除了加上了一个-std=c++11选项外,什么都没干,但现在就把第二次的拷贝构造给去掉了。它是如何实现这一过程的呢?

在老版本中,当我们执行第二行的赋值操作的时候,执行过程如下:

  1. foo()函数返回一个临时对象(这里用~tmp来标识它)
  2. 执行vector的 '=' 函数,将对象k中的现有成员删除,将~tmp的成员复制到k中来

上一篇:win7 winsxs精简 cmd 脚本之 再次 改进版
下一篇:perfect-scrollbar示例

相关文章

相关评论

本站评论功能暂时取消,后续此功能例行通知。

一、不得利用本站危害国家安全、泄露国家秘密,不得侵犯国家社会集体的和公民的合法权益,不得利用本站制作、复制和传播不法有害信息!

二、互相尊重,对自己的言论和行为负责。

好贷网好贷款