c/c++:efficient c++,返回值优化,RVO

返回值优化,是一种属于编译器的技术,它通过转换源代码和对象的创建来加快源代码的执行速度。

RVO = return value optimization。

 

class Complex//复数
{
    friendd Complex operator + (const Complex & , const Complex&);
public:
    Conplex(double r=0.0,double i= 0.0): real(r),imag(i){}
    Complex(const Complex& a):real(a.real),imag(a.imag){};
    Complex operator = (const Complex &a); 
    ~Complex();
private:
    double real;
    double imag;
};

 

 对于执行 A=B+C;

的时候,编译器在原函数创建一个临时变量,作为第三个参数传给 operator +(),使用引用传递,然后再将值赋给 A。

 

很多的编译器都实现了这样的优化,不过在程序编写的时候需要注意某些细节,才能让编译器执行这一技术。如:

//不能使用RVO
Complex operator +(const Complex & a, const Complex &b)
{
    Complex retVal;
    retVal.real=a.real +b.real;
    retVal.imag=a.imag +b.imag;
    return retVal;
}

//能够使用RVO
Complex operator +(const Complex & a, const Complex &b)
{
    double r=a.real +b.real;
    double i=a.imag +b.imag;
    return Complex(r,i);
}

 

//不能使用RVO
Complex operator +(const Complex & a, const Complex &b)
{
    Complex C(a.real +b.real,a.imag +b.imag);
    return C;
}

//能够使用RVO
Complex operator +(const Complex & a, const Complex &b)
{
    return C(a.real +b.real,a.imag +b.imag);
}

 

 

另外,必须定义拷贝构造函数来“打开”RVO

 

另外还有一种是通过 够着函数实现的,称 计算性构造函数

//计算性构造函数
Complex operator +(const Complex& a, const Complex &b)
{
    return Complex(a,b);
}

Complex::Complex(const Complex &a ,const Complex &b):real(a.real +b.real),imag(a.imag +b.imag){}

 

 

 要点:

1.如果必须按值返回函数,通过RVO可以省去创建和销毁局部对象的步骤。

2.RVO 的应用要遵照编译器的实现而定。

3.通过编写计算性函数可以更好的使用RVO。

 

 

 

 

 

 

 

 

 

 

 

你可能感兴趣的:(c/c++)