|
Программирование >> Поддержка объектно-ориентированного программирования
(плюс, унарный и бинарный) (минус, унарный и бинарный) ( умножение) ( деление) ( остаток от деления) То же верно для операций отношения: == (равно) != (не равно) < (меньше чем) <= (меньше или равно) >= (больше или равно) Для операций присваивания и арифметических операций в С++ выполняются все осмысленные преобразования основных типов, чтобы их можно было неограниченно использовать любые их сочетания: double d; int i; short s; ... d = d + i; i = s * i; Символ = обозначает обычное присваивание. \n является символом конца строки (или перевода строки), поэтому он выдается после символов Hello, world! Целое значение, возвращаемое функцией main(), если только оно есть, считается возвращаемым системе значением программы. Если ничего не возвращается, система получит какое-то мусорное значение. Средства ввода/вывода потоковой библиотеки подробно описываются в главе 1 0. 1.3.2 Переменные и арифметические операции Каждое имя и каждое выражение обязаны иметь тип. Именно тип определяет операции, которые могут выполняться над ними. Например, в описании int inch; говорится, что inch имеет тип int, т.е. inch является целой переменной. Описание - это оператор, который вводит имя в программу. В описании указывается тип имени. Тип, в свою очередь, определяет как правильно использовать имя или выражение. Основные типы, наиболее приближенные к аппаратной реальности машины, таковы: char short int long Они представляют целые числа. Следующие типы: float double long double представляют числа с плавающей точкой. Переменная типа char имеет размер, нужный для хранения одного символа на данной машине (обычно это один байт). Переменная int имеет размер, необходимый для целой арифметики на данной машине (обычно это одно слово). Следующие арифметические операции можно использовать над любым сочетанием перечисленных типов: cm = x; else in = cm = 0; cout << in << in = << cm << cm\n ; Операция >> ( ввести из ) используется как оператор ввода; cin является стандартным входным потоком. Тип операнда, расположенного справа от операции >>, определяет, какое значение вводится; оно записывается в этот операнд. Оператор switch (переключатель) сравнивает значение с набором констант. Проверку в предыдущем примере можно записать так: switch ( ch ) case i: in = x; cm = x * fac; 1.3.3 Указатели и массивы Массив можно описать так: char v [ 10 ]; массив из 10 символов Описание указателя имеет такой вид: char * p; указатель на символ Здесь [] означает массив из , а символ * означает указатель на . Значение нижней границы индекса для всех массивов равно нулю, поэтому v имеет 1 0 элементов: v [ 0 ] ... v [ 9 ]. Переменная типа указатель может содержать адрес объекта соответствующего типа: p = & v [ 3 ]; p указывает на 4-й элемент массива v Унарная операция & означает взятие адреса. 1 .3.4 Условные операторы и циклы В С++ есть традиционный набор выбирающих операторов и циклов. Ниже приводятся примеры операторов if, switch и while. В следующем примере показано преобразование дюйма в сантиметр и обратно. Предполагается, что во входном потоке значение в сантиметрах завершается символом i, а значение в дюймах - символом c: #include <iostream.h> int main () const float fac = 2.54; float x, in, cm; char ch = 0; cout << enter length: ; cin >> x; ввод числа с плавающей точкой cin >> ch ввод завершающего символа if ( ch == i ) { дюйм in = x; cm = x * fac; else if ( ch == c ) { сантиметры in = x / fac; break; case c: in = x / fac; cm = x; break; default: in = cm = 0; break; Операторы break используются для выхода из переключателя. Все константы вариантов должны быть различны. Если сравниваемое значение не совпадает ни с одной из них, выполняется оператор с меткой default. Вариант default может и отсутствовать. Приведем запись, задающую копирование 1 0 элементов одного массива в другой: int v1 [ 10 ]; int v2 [ 10 ]; ... for ( int i=0; i<10; i++ ) v1 [ i ] = v2 [ i ]; Словами это можно выразить так: Начать с i равного нулю, и пока i меньше 10, копировать i-тый элемент и увеличивать i. Инкремент (++) переменной целого типа просто сводится к увеличению на 1 . 1.3.5 Функции Функция - это поименованная часть программы, которая может вызываться из других частей программы столько раз, сколько необходимо. Приведем программу, выдающую степени числа два: extern float pow ( float, int ); pow () определена в другом месте int main () for ( int i=0; i<10; i++ ) cout << pow ( 2, i ) << \n; Первая строка является описанием функции . Она задает pow как функцию с параметрами типа float и int, возвращающую значение типа float. Описание функции необходимо для ее вызова, ее определение находится в другом месте. При вызове функции тип каждого фактического параметра сверяется с типом, указанным в описании функции, точно так же, как если бы инициализировалась переменная описанного типа. Это гарантирует надлежащую проверку и преобразования типов. Например, вызов функции pow(1 2.3, abcd ) транслятор сочтет ошибочным, поскольку abcd является строкой, а не параметром типа int. В вызове pow(2,i) транслятор преобразует целую константу (целое 2) в число с плавающей точкой (float), как того требует функция. Функция pow может быть определена следующим образом: float pow ( float x, int n ) if ( n < 0 ) error ( ошибка: для pow () задан отрицательный показатель ); switch ( n ) case 0: return 1; case 1: return x; default: return x * pow ( x, n-1 ); Первая часть определения функции задает ее имя, тип возвращаемого значения (если оно есть), а также типы и имена формальных параметров (если они существуют). Значение возвращается из функции с помощью оператора return.
|
© 2006 - 2025 pmbk.ru. Генерация страницы: 0
При копировании материалов приветствуются ссылки. |