Такой класс позволяет нам выводить любые целые в двоичном виде, например: short а = -2;
cout << binary(a) << endl;
Однако этот класс выводит в выходной поток всегда такое количество битов, которое содержится в типе unsigned long. Мы легко можем преобразовать этот класс в шаблон, который позволит выводить для беззнаковых целых нужное количество битов (листинг 14.14).
Листинг 14.14. Эффектор-шаблон
// опережающие объявления template <class Т> class binary:
template<class T> ostream& operator<<(ostream& os, const binary<T>& t); // класс-шаблон template <class T> class binary { T k;
public: v
binary(T k): k(k) {}
friend ostream& operator<< <>(ostream& os, const binary<T>& t);
};
template<class T> inline
ostream& operator<<(ostream& os, const binary<T>& t) { T MAX = numer.ic__limits<T>: :max();
T bit = -(MAX >> 1);
while(bit)
{ os « (t.k & Mt?'l' : '0'): bit >>= 1; } return os;
}
Обратите внимание на опережающие объявления и прототип функции-шаблона operator<< в классе binary.
Использовать данный класс-шаблон в качестве манипулятора можно так: short а = -2:
cout << binary<unsigned short>(a) << endl: cout << binary<unsigned char>(128)<< endl:
В результате на экран выводится следующее:
1111111111111110 10600000
Как видим, на экране ровно столько битов, сколько занимают типы unsigned short и unsigned char. Заметим, что использовать в качестве аргумента шаблона знаковый тип нельзя — программа зациклится!
Упражнения
1. Написать три варианта функции, которая вычисляет корень квадратного уравнения ах1 + Ъх + с = 0. Все три варианта должны генерировать исключения в случае какой-либо ошибки. Первый вариант функции должен включать полную спецификацию исключений, второй — «пустую» спецификацию throw(), в третьем варианте спецификация исключений должна отсутствовать. Определить собственные типы исключений.
2. Выполнить предыдущее задание, реализовав подмену стандартной функции unexpected (). Пользовательская функция должна выводить сообщение об отсутствии обработчика исключения и заканчивать работу.
3. Реализовать класс-стек (см. листинг 6.9), обеспечив обработку исключений. Исключения определить как независимые пустые классы.
4. Определить подходящие исключения в открытой части и модифицировать методы класса double (см. упражнение 2 в главе 2): в случае возникновения ошибок все методы должны генерировать подходящие исключения. |