Re: Reference assignment through base class reference
 
James Kanze wrote:
On Jun 5, 7:27 pm, "Victor Bazarov" <v.Abaza...@comAcast.net> wrote:
James Kanze wrote:
On Jun 5, 3:06 pm, "Victor Bazarov" <v.Abaza...@comAcast.net> wrote:
James Kanze wrote:
[..]
In general, assignment doesn't work well with polymorphic
objects.  Typically, if a class is designed to be used as a
base, it will have a private assignment operator, so that such
code will be illegal.
*Private* assignment operator?  Not *protected*?  Just trying to
clarify...
Private.  Why would you make it protected, if the goal is to ban
it?  Alternatively, you could inherit from something like
boost::uncopiable.
If a class is designed to be used as a base, and its assignment op
is private, how the hell are you going to copy the derived class
objects?
You're not going to assign them.  (A protected copy constructor
is sometimes appropriate.  Although in most cases, if a class is
designed to be used as a base class, it has no data to be
copied.)
"In most cases" is no substitute for "in general".  In general even
a class designed to be a base class _may_ contain data [to be copied].
So, in my book, *in general* the copy assignment operator cannot be
private, it has to be protected.
The default copy assignment op cannot be generated, so
a user-defined has to be provided, which will have to forgo copying
of the base part, which means only the derived portion can be made
"the same as the other one", and the base class subobject will have
to stay the way it was created...
No.  The derived class doesn't have to do anything.  Assignment
is just not part of the contract, and thus not supported.
WHAT contract are you talking about?  "Assignable" is a requirement
for an object to be stored in a standard container, for example.
V
-- 
Please remove capital 'A's when replying by e-mail
I do not respond to top-posted replies, please don't ask