Компьютеры хранят данные как последовательность битов, каждый из которых содержит 0 или 1:
00011011011100010110010000111011 ...
Большинство компьютеров оперируют с памятью, разделенной на порции, размер которых в битах кратен степеням числа 2. Наименьшая порция адресуемой памяти называется
У большинства компьютеров каждый байт памяти имеет номер, называемый
736424 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 |
736425 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 |
736426 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 |
736427 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 |
Слева представлен адрес байта, а 8 битов его значения — справа.
При помощи адреса можно обратиться к любому из байтов, а также к набору из нескольких байтов, начинающемуся с этого адреса. В этом случае говорят о доступе к байту по адресу 736424 или о байте, хранящемуся по адресу 736426. Чтобы получить представление о значении в области памяти по данному адресу, следует знать тип хранимого в ней значения. Именно тип определяет количество используемых битов и то, как эти биты интерпретировать.
Если известно, что объект в области по адресу 736424 имеет тип float
, и если тип float
на этой машине хранится в 32 битах, то известно и то, что объект по этому адресу охватывает все слово. Значение этого числа зависит от того, как именно машина хранит числа с плавающей запятой. Но если объект в области по адресу 736424 имеет тип unsigned char
, то на машине, использующей набор символов ISO-Latin-1, этот байт представляет точку с запятой.
Типы с плавающей точкой представляют значения с одиночной, двойной и расширенной точностью. Стандарт определяет минимальное количество значащих цифр. Большинство компиляторов обеспечивает большую точность, чем минимально определено стандартом. Как правило, тип float
представляется одним словом (32 бита), тип double
— двумя словами (64 бита), а тип long double
— тремя или четырьмя словами (96 или 128 битов). Типы float
и double
обычно имеют примерно по 7 и 16 значащих цифр соответственно. Тип long double
зачастую используется для адаптации чисел с плавающей запятой аппаратных средств специального назначения; его точность, вероятно, также зависит от конкретной реализации этих средств.
За исключением типа bool
и расширенных символьных типов целочисленные типы могут быть
Типы int
, short
, long
и long long
являются знаковыми. Соответствующий беззнаковый тип получают добавлением части unsigned
к названию такого типа, например unsigned long
. Тип unsigned int
может быть сокращен до unsigned
.