Possible Duplicate:
C++: What is the size of an object of an empty class?
Why does the following output 1
?
#include <iostream>
class Test
{
};
int main()
{
std::cout << sizeof(Test);
return 0;
}
The standard does not allow objects (and classes thereof) of size 0, since that would make it possible for two distinct objects to have the same memory address. That's why even empty classes must have a size of (at least) 1.
To ensure that the addresses of two different objects will be different. For the same reason, "new" always returns pointers to distinct objects.
See Stroustrup for complete answer.
The C++ standard guarantees that the size of any class is at least one. The C++ standard states that no object shall have the same memory address as another object. There are several good reasons for this.
To guarantee that
new
will always return a pointer to a distinct memory address.To avoid some divisions by zero. For instance, pointer arithmetics (many of which done automatically by the compiler) involve dividing by
sizeof(T)
.
Note however that it doesn't mean that an empty base-class will add 1 to the size of a derived class:
struct Empty { };
struct Optimized : public Empty {
char c;
};
// sizeof(Optimized) == 1 with g++ 4.0.1
Bjarne Stroustrup talks about this too.
Class without any data members and member function such type of class is known as empty class. Size of object of empty class is always 1 byte.
When we create object of any class at that time object always gets 3 characteristics i.e.
- State
- Behaviour
- Identity
When we create object of empty class at that time State of that object is nothing. Behaviour of that object is also nothing, but compiler assigns a unique address to that object. Memory in Computer is always organized in the form of bytes and minimum memory available at object address location is 1 byte. That's why size of object of empty class is 1 byte.
What Maurits and Péter said.
It is interesting to note in this context that compilers can do empty base class optimization (EBCO):
#include <iostream>
struct Foo {};
struct Bar : Foo {};
int main () {
std::cout << sizeof(Foo) << ',' << sizeof(Bar) << std::endl;
}
This will probably print "1,1" if you compile and run it. See also Vandevoorde/Josuttis 16.2 on EBCO.
精彩评论