Алгебраические типы данных в 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, и теперь используется очень много где.

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

Архив записей в блогах:
С утра в новостях показали какую-то совершенно безумную историю про то, как где-то в Колыме программист уже 4 года таскается по судам по иску, который направили в суд потому что пиратская копия его программы глючит, а лицензионная, по истечении ...
Я хотела узнать,можно ли как-то разобраться с фотографиями?Я не люблю их в электронном виде,мне нравятся альбомы.Но как,с чего начать?ккаждому событию покупать новый альбом? укладываться в определенный формат,чтобы на полке смотрелось ...
С 2012 года мир может перейти на новый календарь.С инициативой замены нынешнего ...
... сократить рабочий день по крайней мере до 6, а потом и до 5 часов… ... ввести общеобязательное политехническое обучение, необходимое для того, чтобы члены общества имели возможность свободно выбирать профессию и не быть прикованными на всю жизнь к одной какой-либо профессии…. ... ко ...
«Остановить террор» и освободить Навального потребовали – да, именно потребовали – от властей России подписанты очередного громкого «открытого письма». Его опубликовал человек с ...