From: Weiqi Gao Newsgroups: comp.os.msdos.djgpp Subject: Re: no copy-ctor for temps Date: Sat, 02 Oct 1999 13:40:17 -0500 Organization: CRL Network Services Lines: 33 Message-ID: <37F65191.DE3DF578@a.crl.com> References: <37F562D4 DOT 57291365 AT a DOT crl DOT com> NNTP-Posting-Host: a116011.stl1.as.crl.com Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Transfer-Encoding: 7bit X-Mailer: Mozilla 4.51 [en] (X11; I; Linux 2.2.5-15 i586) X-Accept-Language: en To: djgpp AT delorie DOT com DJ-Gateway: from newsgroup comp.os.msdos.djgpp Reply-To: djgpp AT delorie DOT com "Wendy E. McCaughrin" wrote: > > 2 questions: > > 1. Your reference for the above assertion? [1] Bjarne Stroustrup, The C++ Programming Language, 3rd. ed., Addison-Wesley, Reading, MA, 1997, p. 145, ll.(-12)--(-11). > 2. You say that the new object is merely constructed at the place > where temp is allocated -- how is this different from bit-wise > copy? By "construct" do you mean the char* ctor is invoked to > build 'temp' -- then I agree it is not bit-wise copy. But you > express it like assignment, which defaults to bit-wise copy. I goofed on the second temp. I should have written: TstCpy(Overflow(" I an a temporary\n")); is akin to Overflow temp(" I an a temporary\n"); which does not invoke the copy constructor, but invokes the constructor to construct temp directly on the stack of TstCpy(). BTW. You can see the constructor being called by either inserting a debugging "cout <<" inside the constructor, or by stepping through the code with gdb. -- Weiqi Gao weiqigao AT a DOT crl DOT com