首先理解临时对象的概念
<pre name="code" class="cpp">template<class T> void Swap(T& object1,T& object2) { T temp = object1; object1 = object2; object2 = temp; }上述中的temp只是函数的一个局部对象,而真正的临时对象时看不见的!
临时对象通常在两种条件下产生。
1.为了使函数调用成功进行隐式转换
2.函数返回对象时
临时对象对程序的性能开销影响很大,必须要关注。
size_t choutChar(const string& str,char ch) char buffer[MAX_STRING_LEN]; char c; countChar(buffer,c);//此时就会产生临时对象
临时对象仅在传值或传递常量型引用时才会产生,对于非常量引用时无法产生的。
即:
void uppercasify(string& str); //此时不会产生临时对象,不会发生隐士转换。仔细思考一下就会明白,此时发生隐式转换会有问题。
另外一种产生临时对象的情况是函数返回对象时,
const Number operator+(const Number& lhs, const Number& rhs);
这个函数的返回值是临时的,因为它没有被命名。对于此类临时对象很难避免,但是我们可以优化:
以以下函数为例:
const Rational operator*(const Rational& lhs, const Rational &rhs);一种推荐的非常高效的方法是返回constructor argument而不是直接返回对象
const Rational operator*(const Rational& lhs,const Rational& rhs) { return Rational(lhs.numerator()*rhs.numerator(), lhs.denominator()* rhs.denominator()); }
这是一个临时对象,函数把它拷贝给函数的返回值。
c++规则允许编译器优化不出现的临时对象,因此如果你在以下环境里调用operator*:
Rational a = 10; Rational b(1,2); Rational c = a * b;
编译器会消除此时operator*的临时对象,及调用一个构造函数即可建立对象C,非常高效。