C/C++教程

c++17 返回值优化

本文主要是介绍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优化的,但是返回一个有名字的对象会分很多情况,根据具体情况具体选择优化方法即可

这篇关于c++17 返回值优化的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!