[Development] What's the status of a moved-from object?
Thiago Macieira
thiago.macieira at intel.com
Sun May 19 18:54:08 CEST 2019
On Sunday, 19 May 2019 05:24:14 PDT Giuseppe D'Angelo via Development wrote:
> Hence, I'll ask here: what should the status of a moved-from object be?
> I'm not really interested in _how_ to achieve such status (although of
> course it's very important, and should influence the decision); I'm
> interested in what's our contract with our users.
I think there are two answers: what an object MUST be and what it SHOULD be.
Obviously, the object must be destructible. And at a minimum, the object
should be assignable, so a new, valid state can be created.
This is the bare minimum. I'd also add that the moved-from object does not
hold non-negligible resources still allocated. Classes that allocate O(n) or
worse memory, not O(1) like the d pointer.
But I think all Qt classes should go beyond that, unless they have VERY good
reasons not to do so (and document so). The moved-from object should also be
in a valid state so all the accessor and mutation API in the class can operate
in the object without ill effects. What they actually do, we can't tell, since
the initial state is unknowable. So apply the principle of GIGO.
Usually, the easiest way to accomplish that is for the moved-from object to be
reset to the default-constructed state. So this is what the Qt move
constructors and move assignment operators should be aiming at, by default,
unless they have reasons not to.
--
Thiago Macieira - thiago.macieira (AT) intel.com
Software Architect - Intel System Software Products
More information about the Development
mailing list