C 中的临时对象销毁
人们可能想知道由函数调用或构造函数的值参数创建的临时对象何时被销毁。它们消亡的精确时间对于确定涉及临时分配实体的代码的正确执行至关重要。
为了说明该问题,请考虑以下示例:
#include <iostream> struct Foo { const char* m_name; ~Foo() { std::cout << m_name << '\n'; } }; int main() { Foo foo{"three"}; Foo{"one"}; // unnamed object std::cout << "two" << '\n'; }
此代码是否会打印“一二三”?未必。该行为取决于 C 编译器和用于编译的特定设置。
根据 C 标准 ([class.temporary] p4),临时对象的生命周期持续到其创建的完整表达式结束为止在提供的示例中,完整的表达式是整个 main 函数。因此,临时 Foo 对象的销毁发生在 main 的末尾,这符合观察到的打印顺序。
但是,[class.temporary] p5、p6 和 p7 定义了此一般规则的几个例外。例如,可以缩短数组初始化时临时对象的生命周期。此外,将引用绑定到临时对象或在 for-range-initializer 中使用它可以延长其生命周期。
总之,C 中临时对象销毁的精确时间由标准控制。虽然在大多数情况下,临时变量在创建它们的表达式末尾被销毁,但某些异常和编译器优化可以改变这种行为。理解这些细微差别对于编写正确且可预测的 C 代码至关重要。
以上是C中的临时对象什么时候被销毁?的详细内容。更多信息请关注PHP中文网其他相关文章!