c++17 返回值优化

返回值优化(return value optimization, RVO)是一种减少开销的行为

下面一段代码定义了一个结构体,用于显示返回值优化的效果

static int counter; // counter to identify instances of S

struct S {
    int i{ 0 };
    int id;

    S() : id{ ++counter } {
        std::cout << "default ctor " << id << "\n";
    }

    S(const S& s) : i{ s.i }, id{ ++counter } {
        std::cout << "copy ctor " << id << "\n";
    }

    S& operator=(const S& s) {
        i = s.i;
        std::cout << "assign " << s.id << " to " << id << "\n";
        return *this;
    }

    ~S() {
        std::cout << "dtor " << id << "\n";
    }
};

如果没有返回值优化:

S get_B() {
    return S(); // 1. default ctor 1
} // 2. copy ctor 2; 3. dtor 1

int main() {
    S s = get_B();
} // 4. dtor 2

会执行一次构造函数,一次拷贝构造
如果有返回值优化

S get_B() {
    return S(); // 1. default ctor 1
}

int main() {
    S s = get_B();
} // 2. dtor 1

只会执行一次构造函数

导致RVO不起作用的写法

下面这个代码还是比预期多执行了一次拷贝赋值

S get_E() {
    S s;         // 2. default ctor 2
    s.i = 5;
    return s;
} // 3. assign 2 to 1; 4. dtor 2


int main() {
    S s;         // 1. default ctor 1
    s = get_E();
} // 5. dtor 1

但是如果返回的对象是有名字的,则不能保证一定会执行返回值优化,具体看编译器怎么做。

总结: 返回一个没有名字的临时对象是可以通过RVO优化的,但是返回一个有名字的对象会分很多情况,根据具体情况具体选择优化方法即可

posted @   yuzuki_n  阅读(238)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示