标签:post tor bool 第一个 程序 条件 目标 避免 运算符
T operator+(const T &, const T &);以及两个T objects,a和b,那么:
a + b;可能会导致一个暂时性对象,以放置传回的对象.是否会导致一个暂时性对象,视编译器的进取性(aggressiveness)以及上述操作发生时的程序上下关系(program context)而定.比如以下这个片段:
T a, b; T c = a + b;编译器会产生一个暂时性对象,放置a+b的结果,然后再使用T的copy constructor,把该暂时性对象当作c的初值.然而更好的转换则是直接以拷贝构造的方式,将a+b的值放到c中,于是就不须要暂时性对象,以及对其constructor和destructor的调用了.
T c = a + b;而当中的加法运算符被定义为:
T operator+(const T &, const T &);或
T T::operator+(const T &);那么实现时根本不产生一个暂时性对象.
c = a + b;不可以忽略暂时性对象.
T c = a + b;总是比以下的操作更有效率地被编译器转换:
c = a + b;第三种运算形式是,没有出现目标对象:
a + b; // no target这时候有必要产生一个暂时对象,以放置运算后的结果.尽管看起来有点怪异,但这样的情况实际上在子表达式中十分普遍.比如,假设这样写:
String s("hello"), t("world"), u("!");那么不论:
String v;
v = s + t + u;或
printf("%s\n", s + t);都会产生一个暂时对象,与s + t相关联.
// tertiary full expression with 5 sub-expressions ((objA > 1024) && (objB > 1024)) ?一种有五个子表达式,内带在一个"?:完毕表达式"中.不论什么一个子表达式所产生的不论什么一个暂时对象,都应该在完整表达式被求值完毕后,才干够销毁.objA + objB : foo(objA, objB);
if (s + t || u + v)当中的u+v子算式仅仅有在s+t被评估为 false 时,才会開始被评估.与第二个子算式有关的暂时性对象必须被销毁.可是,非常显然地,不能够被无条件地销毁.也就是说,希望仅仅有在暂时性对象被产生出来的情况下才去销毁它.(假设第一个子算式为 true,则不产生第二个暂时性对象,不须要销毁)
bool verbose; ... String progNameVersion = !verbose ? 0 : progName + progVersion;当中progName和progVersion都是String objects.这时候会生出一个暂时对象,放置加法运算符的运算结果:
String operator+(const String &, const String &);暂时对象必须依据对verbose的測试结果有条件地解构.在暂时对象的生命规则下,它应该在完整的"?
:表达式"结束评估后尽快被销毁.然而,假设progNameVersion的初始化须要一个copy constructor:
progNameVersion.String::String(temp);那么暂时性对象的解构(在"?
:完整表达式"之后)当然那就不是期望的.C++ Standard要求:
...凡是含有表达式运行结果的暂时性对象,应该存留到object的初始化操作完毕为止.
暂时性对象的生命规则的第二个例外是"当一个暂时性对象被一个reference绑定"时,比如:
const String &space = " ";产生出这种程序代码:
// C++ pseudo Code String temp; temp.String::String(" "); const String &space = temp;非常明显,假设暂时性对象如今被销毁,那个reference也就没实用了.所以C++ Standard要求:
标签:post tor bool 第一个 程序 条件 目标 避免 运算符
原文地址:http://www.cnblogs.com/ljbguanli/p/6914059.html