Операция sizeof

С помощью операции sizeof можно определить размер памяти в байтах, которая соответствует идентификатору, типу данных или какому-то выражению. Операция sizeof имеет следующий формат:

sizeof(операнд)

В качестве операнда не может быть использовано имя типа void, а идентификатор не может относиться к полю битов или быть именем функции.

Семантически это выражение является беззнаковой константой и может быть использовано в любом месте, где требуется константа. В основном эта операция используется для определения пространства, необходимого для динамического создания объекта. Он используется вместе с операторами управления памятью new и delete, при использовании которых редко нужно знать размер представления типа.

Если в качестве операнда указан тип данных, то операция sizeof() выдает число байт, необходимое для представления типа.

Если в качестве операнда указано выражение, результатом будет размер типа выражения.

Например:

#include<stdio.h>

void main()

{

int a;

double b;

printf("%d",sizeof(a*b));

}

даст результат 8 байт такой, если бы было записано sizeof(double) , т.к. результат выражения a*b приводится к типу double.

Если в качестве операнда указано имя массива, то результатом является размер всего массива (т.е. произведение числа элементов на длину типа), а не размер указателя, соответствующего идентификатору массива.

Когда sizeof применяются к имени типа структуры или объединения или к идентификатору имеющему тип структуры или объединения, то результатом является фактический размер структуры или объединения, который может включать участки памяти, используемые для выравнивания элементов структуры или объединения. Таким образом, этот результат может не соответствовать размеру, получаемому путем сложения размеров элементов структуры.

Пример:

struct { char h; int b;double f;} str;int a1;a1 = sizeof(str);

Переменная а1 получит значение, равное 12, в то же время если сложить длины всех используемых в структуре типов, то получим, что длина структуры str равна 7.

Несоответствие имеет место в виду того, что после размещения в памяти первой переменной h длинной 1 байт, добавляется 1 байт для выравнивания адреса переменной b на границу слова (слово имеет длину 2 байта для машин серии IBM PC AT /286/287), далее осуществляется выравнивание адреса переменной f на границу двойного слова (4 байта), таким образом в результате операций выравнивания для размещения структуры в оперативной памяти требуется на 5 байт больше.

В связи с этим целесообразно рекомендовать при объявлении структур и объединения располагать их элементы в порядке убывания длины типов, т.е. приведенную выше структуру следует записать в следующем виде:

struct { double f; int b; char h;} str;