More Effective C++ --- 理解临时对象
来源:互联网 发布:psp模拟器 mac 编辑:程序博客网 时间:2024/05/16 10:37
首先理解临时对象的概念
<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,非常高效。
0 0
- [More Effective C++]条款十九:理解临时对象的来源
- [More Effective C++]条款十九:理解临时对象的来源
- More Effective C++----(19)理解临时对象的来源
- More Effective C++ --- 理解临时对象
- 理解临时对象的来源(More Effective C++_19(效率))
- more effective c++(临时对象的返回值优化)
- More Effective C++ ——019_理解临时对象的来源
- More Effective C++之Item M19:理解临时对象的来源
- More Effective C :理解new和delete
- More Effective C++:理解new和delete
- 《more effective c++》读书笔记
- More Effective C++(2)
- 《More Effective C++》读后感
- 《More Effective C++》笔记
- 《Effective C++》和《More Effective C++》汇总
- 《More Effective C++》读书笔记一
- 《more effective c++》笔记4
- More Effective C++:类型转换
- HDFS的安全模式
- Struts2输入校验(二)非配置文件校验
- Struts1 DispatchAction类
- 开博客第一天
- android反编译-smali语法
- More Effective C++ --- 理解临时对象
- clip\_gradient
- python学习笔记 使用元类
- 正则表达式个符号的含义与基本内容
- Java并发编程:Lock
- java 多态的含义及特征
- 算法-选择排序
- nodejs中require、exports与module.exports的区分
- JZOJ 4826. 【NOIP2016提高A组集训第2场10.30】小澳的葫芦