[comp.lang.c++] this in Heap-/Stack Objects

schmid@jellosub.luftfahrt.uni-stuttgart.de (Georg Schmid) (10/09/90)

Just a simple question:
One of my c++ books (Bruce Eckel, Using C++) states that one
can determine the type (heap- or stack-based) of an instance
at runtime by looking at 'this' in the constructor: 

"... code is secretly generated in a constructor to differ-
entiate between objects created on the stack (the value of
'this' when the constructor is called is non-zero) and objects
created on the free store (the value of 'this' when the con-
structor is called is zero)..."

I tested this with the following little program on an Apollo 
with Apollos (Glockenspiel) C++ 1.2.2:

#include <stdio.h>

class Something
	{
	public:
	Something();
	};

Something::Something()
	{
	printf("This is %lX\n", this);
	}

int main(int, char**)
	{
	Something	a;    
	Something*	b = new Something;
	}

The output is:

This is 3B3C7556
This is 10C00

Am I wrong, is Eckel wrong or is the compiler wrong ?

Any hints appreciated.
 

-- georg

________________________________________________________________________
Georg Schmid, ISD University of Stuttgart, Germany                 
email: schmid@asterix.luftfahrt.uni-stuttgart.de (129.69.110.2)       
voice: +49 711-685-2053                                        
fax:   +49 711-685-3706
________________________________________________________________________

bjaspan@athena.mit.edu (Barr3y Jaspan) (10/10/90)

|> "... code is secretly generated in a constructor to differ-
|> entiate between objects created on the stack (the value of
|> 'this' when the constructor is called is non-zero) and objects
|> created on the free store (the value of 'this' when the con-
|> structor is called is zero)..."

Ack!  Retch!

Perhaps he is right about a particular compiler on a particular machine, but
that does *not* sound like something you can depend on across machines and
implementations.  "Code is secretly generated" for a reason, namely, to hide
an implementation detail.

(BTW, I can tell you that the compilers I've worked with (g++ and cfront 2.0)
have an implicit argument to member functions that conveys the information you
mentioned.  The compiler should not allow you to access it, however.)


Barr3y Jaspan, bjaspan@athena.mit.edu

brucee@alice.att.com (Bruce Ellis) (10/11/90)

Geroge Schmid says:
> One of my c++ books (Bruce Eckel, Using C++) states that one
etc etc

Don't buy this book.  I flipped through it in a book store and
decided it was probably pretty decent.  I bought it.  I read it.

It contains a lot of bad explanations and bad examples.
An early example program 'detabs' a file my replacing tabs
religously with 8 spaces.  Not a good solution.
Don't buy this book.

------
This is not necessarily the view of my employer.

roman@hri.com (Roman Budzianowski) (10/11/90)

	|> "... code is secretly generated in a constructor to differ-
	|> entiate between objects created on the stack (the value of
	|> 'this' when the constructor is called is non-zero) and objects
	|> created on the free store (the value of 'this' when the con-
	|> structor is called is zero)..."

	Ack!  Retch!


You don't have to look at anything secret to determine if an object is
on the stack.
Compare the value of 'this' to some value you know is on the stack. The
comparison is machine dependent and nonportable.