sizeof(x)
возвращает объем памяти (в байтах), который занимает переменная или тип x
. Это не имеет ничего общего со значением переменной.
Например, если у вас есть массив произвольного типа T
, тогда расстояние между элементами этого массива точно равно sizeof(T)
.
int a[10];
assert(&(a[0]) + sizeof(int) == &(a[1]));
При использовании с переменной это эквивалентно использованию с типом этой переменной:
T x;
assert(sizeof(T) == sizeof(x));
Как правило, лучше по возможности использовать имя переменной, на случай, если тип изменится:
int x;
std::cout << "x uses " << sizeof(x) << " bytes." << std::endl
// If x is changed to a char, then the statement doesn't need to be changed.
// If we used sizeof(int) instead, we would need to change 2 lines of code
// instead of one.
При использовании в пользовательских типах sizeof
по-прежнему возвращает объем памяти, используемый экземплярами этого типа, но стоит отметить, что это необязательно равно сумме его членов.
struct Foo { int a; char b; };
Хотя sizeof(int) + sizeof(char)
обычно составляет 5
, на многих машинах sizeof(Foo)
может быть 8
, поскольку компилятору необходимо дополнить структуру, чтобы она лежала на границах 4 байтов. Это не всегда так, и вполне возможно, что на вашей машине sizeof(Foo)
будет 5, но вы не можете зависеть от этого.