Алгебраические типы данных в Java.

топ 100 блогов ru_java20.01.2010

Алгебраические типы данных (algebraic data types, ADT) — это такая штука, без которых не обходится ни один программист на функциональных языках (тех их них, в которых есть типы), но они могут пригодиться и в объектно-ориентированных. В ООП алгебраические типы данных занимают (могут занимать) промежуточное положение между enumerations и полноценной иерархией классов. В хорошем, годном языке Scala ADT есть (там они называются case classes), но в нашей нищебродской джаве их нет, как нет и многих других вкусностей. А хочется. Давайте попробуем разобраться, как бы их можно заполучить.

Возьмём типичный пример применения ADT: множество способов проведения платежа (точнее, биллинговой информации) в интернет-магазине. Допустим, у нас есть следующие опции:

  • оплата наличными при доставке курьером (cash on delivery);
  • оплата кредитной карточкой;
  • выставление счёта.

В таком языке как Haskell это можно описать прямо дословно (пример невозбранно стырен из книги Real World Haskell):

Практически дословно эту конструкцию можно перевести в Scala:

В Java, конечно, мы лишены такого счастья. Но кое-что всё-таки можно сделать.

Обычно начинают с того, что делают всю иерархию классов. Потом вспоминают, что создавать новый инстанс класса CashOnDelivery каждый раз — не очень умно, и делают его синглтоном. Потом понимают, что совершенно разный синтаксис обращения к подтипам — не очень кошерно, и делают либо кэш в виде HashMap, либо просто поля в каком-то надклассе. В конечном счёте можно прийти вот к такой конструкции:

Всё это, конечно, страшно нарушает священный талмуд сановских Code Conventions for Java, но зато делает возможным почти настоящий синтаксис работы с ADT:

Матчинг, правда, приходится делать через instanceof:

Но это выглядит достаточно прилично, чтобы можно было пользоваться.

Таким образом, алгебраические типы данных в Java всё же существуют. Но как они это делают!.. (с) Соответственно, любой разумный человек должен переключаться на Scala сразу же, как это станет возможным. Да, это была провокация. Но помечтать-то можно?

Данная идея принадлежит перу Алгебраические типы данных в Java. [info]akuklev, и теперь используется очень много где.

Оставить комментарий

Архив записей в блогах:
Всем доброго дня! В сообществе я давно, но читаю активно в период младенчества детей, сейчас вот со вторым отлеживаю бока на дневные сны и пасусь тут (ура планшету!). Поговорите со мной о детях? О закрытых и не закрытых гештальтах. Когда родилась дочка я точно знала что будет ещё один р ...
Попытки монашествующих регламентировать сексуальную жизнь супругов-христиан, напоминают потуги к живописи у слепорожденного. ИМХО конечно ))) ...
Профсоюзы и Союз предпринимателей возмущены тем, что последний вариант пенсионной формулы не предполагает перерасчета пенсии для продолжающих трудиться пожилых людей. Пенсионная формула уже получила «добро» в правительстве, прошла общественные обсуждения и в своей последней версии ...
В суровой мужской компании сходили в киношку на Топ Гана Маврика. Крепкий производственный фильм, борьба хорошего с лучшим, передовые-опытные учат уму-разуму дерзкую молодежь и все вместе достигают высот синтеза. Нельзя не отметить как общевизуальную приятность, так и немыслимую ...
Дорогие друзья! Зарегистрировалась сегодня в ЖЖ специально, чтобы написать сюда. Читаю сообщество давно, но не было повода самой что-то писать, но сейчас нужна ваша помощь (советом). Номера, кстати - Р300Ме и С047НМ Почти каждую ночь на площадке около цирка собирается молодежь на машин ...