Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Методичка_Ч1(программирование).doc
Скачиваний:
52
Добавлен:
01.03.2016
Размер:
1.83 Mб
Скачать
      1. Арифметичні типи даних

До арифметичного типу даних у С++ відносять дані, до яких можна застосовувати усі арифметичні операції.

Ці типи поділяють на основні та модифіковані.

Основні арифметичні типи

Основними типами є такі:

char – тип для символів;

int – тип для цілих чисел;

float – тип для дійсних чисел;

double – дійсні числа подвійної точності;

bool – логічний тип, що може приймати значення 0, або 1.

У читача може створитися враження, що тут помилка. Дійсно дивно, що типи char та bool віднесені до арифметичного типу. Але помилки тут нема. Вираз 'Z'*true є допустимим у С і його можна обчислити. Результатом буде число 90, бо true перетворюється у 1, а код символу ’Z’ дорівнює 90. Тобто логічну змінну і символ можна розглядати як цілі числа.

Слід також прийняти до уваги, що тип bool з’явився тільки у мові С++. А в мові С число 0 розглядалося як true, а будь яке інше число розглядалося як false.

Модифіковані арифметичні типи

Модифіковані типи отримують за допомогою модифікаторів. Значення модифікаторів та типи, до яких їх можна застосовувати показані у таблиці 2.1.

Таблиця 2.1 – Модифікатори для типів мови С++

Модифікатор

Значення

Застосовують до типів

signed

іззнаком

char,int

unsigned

без знаку

char,int

long

довгий

int,long int,double

short

короткий

int

Як бачимо, використання модифікаторів обмежено, за виключенням типу int, до якого можна застосувати будь який модифікатор. Та на практиці область використання ще вужча. Модифікатор signed практичного сенсу не має, бо за принципом замовчування усі типи мають знак. Для знаку виділяється старший біт коду числа. Якщо значення цього біту нуль, то число додатне, якщо одиниця - то від’ємне.

Модифікатор short зменшує удвічі довжину типу int, а модифікатор long збільшує удвічі довжину основного типу. Модифікатор long для типу int можна використовувати двічі. У цьому разі розмір типу int збільшується у чотири рази. Ці модифікатори можна комбінувати з модифікатором unsigned.

У Qt можливі і скорочення, що визначені у заголовному файлі <qtglobal>. Наприклад, замість типу unsigned int можна писати uint. Перелік скорочених назв типів наведено у таблиці 2.2. У цій же таблиці наведено перелік відповідних типів бібліотеки QT, які також визначені у заголовному файлі <qtglobal>.

Граничні значення даних цілочислових типів даних

Граничні значення різних типів даних можуть залежати від програмного середовища та типу комп’ютера. Для тогощоб зменшити цю залежність, у заголовному файлі <climits> записано набір констант, значення яких дорівнюють мінімальним та максимальним значенням кожного цілочислового типу.Мінімальне значення усіх без знакових констант дорівнює 0.

Таблиця 2.2 – Скорочені назви та граничні константи для типів С++

Повна назва типу

Скорочена назва

Тип Qt

Граничні константи

char

char

qint8

CHAR_MIN

char

char

qint8

CHAR_MAX

unsigned char

uchar

quint8

UCHAR _MAX

short

short

qint16

SHRT_MIN

short

short

qint16

SHRT_MAX

unsigned short

ushort

quint16

USHRT_MAX

int

int

qint32

INT_MIN

int

int

qint32

INT_MAX

unsigned int

uint

quint32

UINT_MAX

long int

long

qint64

LONG_MIN

long int

long

qint64

LONG_MAX

unsigned long int

ulong

quint64

ULONG_MAX

long long int

long long

qlonglong

LLONG_MIN

long long int

long long

qlonglong

LLONG_MAX

unsigned long long int

?

qulonglong

ULONG_LONG_MAX