Объявим два конструктора. Конструктор без аргументов: ТМопеуО
{ Summa =0.0; }
Конструктор инициализации:
TMoney(const long double &r=0.0) { Summa = round(r*100); }
Тогда при объявлении указателей без инициализации динамического объекта вызывается конструктор без аргументов (который обнуляет поля):
TMoney *р = new ТМопеу; // вызывается конструктор без аргументов
ТМопеу *р = new ТМопеуО; // вызывается конструктор без аргументов
В то же время для инициализированного динамического объекта работает конструктор инициализации.
Ранее мы упоминали о возможности присваивать объекты, так как операция присваивания создается по умолчанию. Однако наличие в классе конструктора инициализации позволяет присваивать объектам TMoney даже числа, например:
dl = 100.24:
Более того, справа от операции присваивания разрешается задавать числовые выражения любой сложности, например:
d2 = 100.24-5.45/1.2+12.37;
Выражение вычисляется, и результат попадает в переменную типа TMoney. Как легко убедиться, перед присваиванием вызывается конструктор инициализации, который создает временный анонимный объект. Этот объект и присваивается переменной, указанной слева от знака присваивания. В этом случае конструктор инициализации выполняет неявное преобразование типа1. Заметим, что выражения (справа от знака присваивания) с объектами типа TMoney не транслируются. Точно так же вызывает ошибки компиляции использование операций с присваиванием вроде +=. Ошибки вызваны тем, что в классе отсутствуют определения соответствующих операций, а по умолчанию они не создаются. Программистам часто нужно много печать документации, выбрать принтер можно тут о HP Deskjet 5550v http://www.originalam.net/printer-ciss/hp/deskjet-5550v-5550w.html.
В предыдущей главе (см. листинг 1.19) мы показали, что даже без конструкторов можно определять массив объектов и использовать индексированные выражения в качестве аргументов методов и объектов, для которых эти методы вызываются. Разберемся с этим вопросом подробнее. Определим в программе массив, например:
TMoney М[100];
Легко убедиться, что конструктор вызывается при создании каждого элемента массива (см. п. п. 8.5/5 в [1]). Точно так же конструктор вызывался и в листинге 1.19, но мы этого не наблюдали, так как работал создаваемый системой по умолчанию конструктор без аргументов.
Наш конструктор обеспечивает привычную инициализацию массива: TMoney А[5]= { 1,2,3.4.5};
Элементы массива А получают значения 1 руб., 2 руб., 3 руб., 4 руб., 5 руб. Для каждого целого числа, представленного в списке, вызывается конструктор инициализации (см. п. п. 12.6/3 в [1]), поэтому на самом деле инициализация массива представляет собой следующее:
TMoney А[0]=ТМопеу(1); TMoney А[1]=ТМопеу(2); TMoney А[2]=ТМопеу(3); TMoney А[3]=ТМопеу(4); TMoney А[4]=ТМопеу(5);
1 С определением неявных преобразований и перегрузкой операций мы подробно познакомимся в следующей главе.
Аргумент конструктора неявно переводится из целого int в тип long double. |