This is an unofficial snapshot of the ISO/IEC JTC1 SC22 WG21 Core Issues List revision 116a. See http://www.open-std.org/jtc1/sc22/wg21/ for the official list.
2024-12-19
[Accepted as a DR at the February, 2019 meeting.]
According to 6.5 [basic.lookup] bullet 1.4, the following example has defined behavior because the lifetime of n extends until its storage is released, which is after a's destructor runs:
void f() { struct A { int *p; ~A() { *p = 0; } } a; int n; a.p = &n; }
It would be more consistent if the end of the lifetime of all objects, regardless of whether they have a non-trivial destructor, were treated the same.
Notes from the March, 2018 meeting:
CWG agreed with the suggested direction.
Proposed resolution (November, 2018):
Change 6.7.4 [basic.life] paragraph 1 as follows:
The lifetime of an object or reference is a runtime property of the object or reference.
An object is said to have non-vacuous initialization if it is of a class or array type and it or one of its subobjects is initialized by a constructor other than a trivial default constructor. [Note: : Initialization by a trivial copy/move constructor is non-vacuous initialization. —end note]A variable is said to have vacuous initialization if it is default-initialized and, if it is of class type or (possibly multi-dimensional) array thereof, that class type has a trivial default constructor. The lifetime of an object of type T begins when:
storage with the proper alignment and size for type T is obtained, and
if the object has non-vacuous initialization,its initialization (if any) is complete (including vacuous initialization) (9.4 [dcl.init],except that if the object is a union member or subobject thereof, its lifetime only begins if that union member is the initialized member in the union (9.4.2 [dcl.init.aggr], 11.9.3 [class.base.init]), or as described in 11.5 [class.union]. The lifetime of an object o of type T ends when:
if T is a non-class type, the object is destroyed, or
if T is a class type
with a non-trivial destructor (11.4.7 [class.dtor]), the destructor call starts, orthe storage which the object occupies is released, or is reused by an object that is not nested within o (6.7.2 [intro.object]).
Change 6.9.3.4 [basic.start.term] paragraphs 1 and 2 as follows:
Destructors (11.4.7 [class.dtor]) for initializedConstructed objects (that is, objects whose lifetime (6.7.4 [basic.life]) has begun9.4 [dcl.init]) with static storage duration,are destroyed and functions registered with std::atexit,are called as part of a call to std::exit (17.5 [support.start.term]). The call to std::exit is sequenced before theinvocations of the destructorsdestructions and the registered functions. [Note: Returning from main invokes std::exit (6.9.3.1 [basic.start.main]). —end note]
Destructors for initializedConstructed objects with thread storage duration within a given thread arecalleddestroyed as a result of returning from the initial function of that thread and as a result of that thread calling std::exit. Thecompletions of the destructors fordestruction of allinitializedconstructed objects with thread storage duration within that thread strongly happens beforethe initiation of the destructors ofdestroying any object with static storage duration.
Change 8.7 [stmt.jump] paragraph 2 as follows:
...[Note: However, the program can be terminated (by calling std::exit() or std::abort() (17.5 [support.start.term]), for example) without destroyingclassobjects with automatic storage duration. —end note]
Change 8.8 [stmt.dcl] paragraph 2 as follows:
It is possible to transfer into a block, but not in a way that bypasses declarations with initialization (including ones in conditions and init-statements). A program that jumps92 from a point where a variable with automatic storage duration is not in scope to a point where it is in scope is ill-formed unless the variable hasscalar type, class type with a trivial default constructor and a trivial destructor, a cv-qualified version of one of these types, or an array of one of the preceding types and is declared without an initializervacuous initialization (9.4 [dcl.init]). In such a case, the variables with vacuous initialization are constructed in the order of their declaration. [Example:...
Change 8.8 [stmt.dcl] paragraph 5 as follows:
The destructor for aA block-scope object with static or thread storage duration will beexecuteddestroyed if and only if it was constructed. [Note: 6.9.3.4 [basic.start.term] describes the order in which block-scope objects with static and thread storage duration are destroyed. —end note]
Change 9.4 [dcl.init] paragraph 21 as follows:
An object whose initialization has completed is deemed to be constructed, even if the object is of non-class type or no constructor of the object's class is invoked for the initialization. [Note: Such an object might have been value-initialized or initialized by aggregate initialization (9.4.2 [dcl.init.aggr]) or by an inherited constructor (11.9.4 [class.inhctor.init]). —end note] Destroying an object of class type invokes the destructor of the class. Destroying a scalar type has no effect other than ending the lifetime of the object (6.7.4 [basic.life]). Destroying an array destroys each element in reverse subscript order.
Change 11.4.7 [class.dtor] paragraph 2 as follows:
A destructor is used to destroy objects of its class type.The address of a destructor...
Change 14.3 [except.ctor] paragraphs 1 and 2 as follows:
As control passes from the point where an exception is thrown to a handler,
destructors are invokedobjects with automatic storage duration are destroyed by a process, specified in this subclause, called stack unwinding.
The destructor is invoked for each automatic object of class typeEach object with automatic storage duration is destroyed if it has been constructed, but not yet destroyed, since the try block was entered. If an exception is thrown during the destruction of temporaries or local variables for a return statement (8.7.4 [stmt.return]), the destructor for the returned object (if any) is also invoked. The objects are destroyed in the reverse order of the completion of their construction. [Example:...