52700.fb2 Учебник по Haskell - читать онлайн бесплатно полную версию книги . Страница 31

Учебник по Haskell - читать онлайн бесплатно полную версию книги . Страница 31

Sun

it :: Week

Теперь наши дни отображаются. Я выпишу ещё один пример экземпляра для Time, а остальные достанутся

вам в качестве упражнения.

30 | Глава 2: Первая программа

instance Show Time where

show (Time h m s) = show h ++ ”:” ++ show m ++ ”:” ++ show s

instance Show Hour where

show (Hour h) = addZero (show h)

instance Show Minute where

show (Minute m) = addZero (show m)

instance Show Second where

show (Second s) = addZero (show s)

addZero :: String -> String

addZero (a:[]) = ’0’ : a : []

addZero as

= as

Функцией addZero мы добавляем ноль в начало строки, в том случае, если число однозначное, также в

этом определении мы воспользовались тем, что для типа целых чисел Int экземпляр Show уже определён.

Проверим в интерпретаторе:

*Calendar> Time (Hour 13) (Minute 25) (Second 2)

13:25:02

it :: Time

2.5 Автоматический вывод экземпляров классов типов

Для некоторых стандартных классов экземпляры классов типов могут быть выведены автоматически.

Это делается с помощью директивы deriving. Она пишется сразу после объявления типа. Например так мы

можем определить тип и экземпляры для классов Show и Eq:

data T = A | B | C

deriving (Show, Eq)

Отступ за deriving обязателен, после ключевого слова в скобках указываются классы, которые мы хотим

вывести.

2.6 Арифметика

В этом разделе мы обсудим основные арифметические операции. В Haskell много стандартных классов,

которые группируют различные типы операций, есть класс для сравнения на равенство, отдельный класс для

сравнения на больше/меньше, класс для умножения, класс для деления, класс для упорядоченных чисел, и

много других. Зачем такое изобилие классов?

Каждый из классов отвечает независимой группе операций. Есть много объектов, которые можно только

складывать, но нельзя умножать или делить. Есть объекты, для которых сравнение на равенство имеет смысл,

а сравнение на больше/меньше – нет.

Для иллюстрации мы воспользуемся числами Пеано, у них компактное определение, всего два конструк-

тора, которых тем не менее достаточно для описания множества натуральных чисел:

module Nat where

data Nat = Zero | Succ Nat

deriving (Show, Eq, Ord)

Конструктор Zero указывает на число ноль, а (Succ n) на число следующее за данным числом n. В

последней строчке мы видим новый класс Ord, этот класс содержит операции сравнения на больше/меньше:

Prelude> :i Ord

class (Eq a) => Ord a where

compare :: a -> a -> Ordering

(< ) :: a -> a -> Bool