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

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

inv a

= not a

Отметим важность наличия свойств (ограничений) у значений, определённых в классе типов. Так, на-

пример, в классе типов “сравнение на равенство” для любых двух значений данного типа одна из операций

должна вернуть “истину”, а другая “ложь”, то еесть два элемента данного типа либо равны, либо не рав-

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

элементов данного типа свойства понятия равенства не нарушаются.

На самом деле приведённое выше определение экземпляра для Group не верно, хотя по типам оно под-

ходит. Оно не верно как раз из-за нарушения свойств. Для группы необходимо, чтобы для любого a выпол-

нялось:

inv a + a == e

У нас лишь два значения, и это свойство не выполняется ни для одного из них. Проверим:

inv True

+ True

=> (not True) + True

=> False

+ True

=> and False

True

=> False

inv False

+ False

=> (not False) + False

=> True

+ False

=> and True

False

=> False

Проверять свойства очень важно, потому что другие люди, читая ваш код и используя ваши функции,

будут на них рассчитывать.

20 | Глава 1: Основы

1.6 Ядро Haskell

Фуууухх. Мы закончили наш пробег. Теперь можно остановиться, отдышаться и подвести итоги. Давайте

вспомним синтаксические конструкции, которые нам встретились.

Модули

module New(edef1, edef2, ... , edefN) where

import Old1(idef11, idef12, ... , idef1N)

import Old2(idef21, idef22, ... , idef2M)

...

import OldK(idefK1, idefK2, ... , idefKP)

-- определения :

...

Ключевые слова: module, where, import. Мы определили модуль с именем New, который экспортирует

определения edef1, edef2, … , edefN. И импортирует определения из модулей Old1, Old2, и т.д., определения

написаны в скобках за ключевыми словами import и именами модулей.

Типы

Тип определяется с помощью:

• Перечисления альтернатив через |

data Type = Alt1 | Alt2 | ... | AltN

Эту операцию называют суммой типов.