Длинное целое число | 64 бита | |
>float | Число с плавающей запятой одинарной точности | 6 значащих цифр |
>double | Число с плавающей запятой двойной точности | 10 значащих цифр |
>long double | Число с плавающей запятой повышенной точности | 10 значащих цифр |
Тип >bool
представляет только значения >true
(истина) и >false
(ложь).
Существует несколько символьных типов, большинство из которых предназначено для поддержки национальных наборов символов. Базовый символьный тип, >char
, гарантировано велик, чтобы содержать числовые значения, соответствующие символам базового набора символов машины. Таким образом, тип >char
имеет тот же размер, что и один байт на данной машине.
Остальные символьные типы, >wchar_t
, >char16_t
и >char32_t
, используются для расширенных наборов символов. Тип >wchar_t
будет достаточно большим, чтобы содержать любой символ в наибольшем расширенном наборе символов машины. Типы >char16_t
и >char32_t
предназначены для символов Unicode. (Unicode — это стандарт для представления символов, используемых, по существу, в любом языке.)
>int
будет по крайней мере не меньше типа >short
, а тип >long long
— не меньше типа >long
. Тип >long long
введен новым стандартом.
Компьютеры хранят данные как последовательность битов, каждый из которых содержит 0 или 1:
>00011011011100010110010000111011 ...
Большинство компьютеров оперируют с памятью, разделенной на порции, размер которых в битах кратен степеням числа 2. Наименьшая порция адресуемой памяти называется байтом (byte). Основная единица хранения, обычно в несколько байтов, называется словом (word). В языке С++ байт содержит столько битов, сколько необходимо для содержания символа в базовом наборе символов машины. На большинстве компьютеров байт содержит 8 битов, а слово — 32 или 64 бита, т.е. 4 или 8 байтов.
У большинства компьютеров каждый байт памяти имеет номер, называемый адресом (address). На машине с 8-битовыми байтами и 32-битовыми словами слова в памяти можно было бы представить следующим образом:
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, этот байт представляет точку с запятой.