metaclass: (Default)
metaclass ([personal profile] metaclass) wrote2012-10-11 03:22 pm

Динамическая типизация, или статическая типизация для ленивых

Вчера [livejournal.com profile] ivan_gandhi сделал замечание что я, пользуясь динамически типизированной кложурью, при этом требую, чтобы в Java проверяли входные параметры на валидность. (Если что, проверка валидности в дотнете есть на каждом шагу, а объяснения вида "экономят циклы и не делаю проверки" в контексте жабы, тяжелого железа, JIT и прочего звучат крайне странно).
Собирался на эту тему устроить срач с утра, но [livejournal.com profile] thedeemon уже начал, так что я продолжу :)

Так вот, динамически типизированными языками мы пользуемся от бедности - нету статически типизированных языков, которые давали бы ту же функциональность.

Например, я хочу использовать кортеж с именованными полями (потому что позиционные кортежи нихера нечитабельны и их тип вида int*string*smallint*money*bool*Chervie ни о о чем не говорят). От входа в F# при этом нужно:
1) объявить этот чертов record где-то
2) сослаться на модуль с объявлением везде где он нужен
3) создавать экземпляры рекорда кривопачвярными конструкциями, причем оставить поля значениями по умолчанию нельзя.
4) паттерн матчинг с декомпозицией вроде не работает с рекордами.

Хаскель сразу закапываем - там на каждый случай имеется 3-4 расширения и 10 пакетов в hackage различной степени недоделанности, идиоматический подход - писать в point-free style, чтобы коллеги не разобрались, а работать в продакшене можно только с теми сторонними библиотеками, которые я могу сам починить.

При этом, у меня при работе с оперденями постоянно ситуации вида: есть запись с тремя полями, полученная из БД, мне нужно произвести обработку этой записи и добавить результат обработки в виде четвертого поля, получив новый тип записи.
Я НЕ хочу объявлять каждый раз такое руками и в Clojure это делается элементарно, добавлением нового ключа в map в функции-обработчике записей.

При этом РЕАЛЬНО динамическую типизацию я не использую. Она мне почти не нужна, потому что единственная ситуация, где вменяемый человек будет на одном цикле биндить к имени число, на втором строку, на третьем - список записей - это когда по условию задачи нужна, например, EAV-модель во все поля. И то - обычно EAV делается от безысходности, потому что пользователь не может нормально работать со схемой БД, а задача требует чего-нибудь вроде "добавить к части записей атрибут "фаза луны в которую производилась приемка товара"". В норме должны быть зависимые типы и миграции и пользователи бы пользовались той же системой типов что и разработчик.
Т.е. нормальный вывод типов - это когда программа берет типы из тут же описанного SQL-запроса, а рекорды расширяемые и объявлять их не нужно.

Второй use-case, где "вроде бы динамическая типизация" - это когда я делаю документы в виде кложурных структур данных, подгоняя комбинации списков-мапов-массивов-множеств под предметную область. В кложуре же это делается в лоб, а в хаскеле в один список не положишь три разных по структуре(типу) раздела документа. Но на самом деле, то что я делаю в кложури - это просто алгебраический тип данных "для бедных", без объявления заранее и без явно выделенных-именованных конструкторов данных. Если бы была возможность делать расширяемые и объявляемые по месту типы данных (чтобы каждый раз при разработке не переключаться между объявлением типа и конструированием данных по этому типу) - то было бы то же самое что в кложури - но статически типизированное.

PS: На ту же тему: http://justy-tylor.livejournal.com/190153.html

[identity profile] bydl0coder.livejournal.com 2012-10-12 10:53 am (UTC)(link)
Да начиная с hello world. Первая и единственная попытка написать на Хаскеле что-то полезное закончилась стековерфлоу и переписыванием на руби.
У Хаскела очень высокий порог вхождения, который теоркат-гики не особо собираются снижать. Вероятность встретить статью о реализации какого-нибудь квазиморфизма гиперфункторов гораздо выше вероятность встретить статью про, не знаю там, чат-сервер на Comet.

[identity profile] thesz.livejournal.com 2012-10-12 11:36 am (UTC)(link)
Слушайте, ну довольно уж гипербол. С гиперболами вообще нельзя общаться. "Hello, world" не может вызвать переполнение стека.

Касательно чат-сервера - почитайте CUFP. Опять же, ФЯ достаточно разнообразны, чтобы иметь кучу применений.

[identity profile] bydl0coder.livejournal.com 2012-10-12 11:54 am (UTC)(link)
Ок, это был не хелловорлд, но первая потенциально полезная программа на Хаскеле - считала хэш по очень простому алгоритму. Вот Скала концептуально, хм, не очень ("все флаги в гости к нам"), но там сел и поехал.

> Касательно чат-сервера - почитайте CUFP
Да я понимаю, что все есть, краем глаза видел. Просто сообщество, особенно русскоязычное, больше интересуется теоркатом, чем банальными, но полезными вещами. Ну, русские айти-блоггеры вообще народ специфический (сравнить stackoverflow и govnokod.ru)

>чтобы иметь кучу применений.
На мой взгляд, Хаскел подходит для написания коробочных продуктов - ну там баз данных всяких, брокеров очередей и т.п. - всякие статические гарантии полезны, а проблема с квалификацией программистов не так остро стоит. Есть что-нибудь такое?

[identity profile] zw0rk.blogspot.nl (from livejournal.com) 2012-10-12 01:40 pm (UTC)(link)
> На мой взгляд, Хаскел подходит для написания коробочных продуктов - ну там баз данных всяких, брокеров очередей и т.п. - всякие статические гарантии полезны, а проблема с квалификацией программистов не так остро стоит. Есть что-нибудь такое?

Не сказать, что СУБД, но data storage с "гарантиями" http://happstack.com/docs/crashcourse/AcidState.html

[identity profile] bydl0coder.livejournal.com 2012-10-12 01:50 pm (UTC)(link)
Это не коробочный продукт, биндингов для доступа из других языков я не нашел. Вот RabbitMQ какой-нибудь -- коробочный.

[identity profile] zw0rk.blogspot.nl (from livejournal.com) 2012-10-12 01:53 pm (UTC)(link)
Ну тогда PanDoc и libpandoc (https://github.com/toyvo/libpandoc) в нему. Есть и для других языков биндинги, насколько я помню.

[identity profile] bydl0coder.livejournal.com 2012-10-12 01:56 pm (UTC)(link)
Ну блин, конвертилка документов, тоже мне демонстрация крутизны хаскеля. Еще DARCS (которым пользоваться бессмысленно) и xmonad (который вполне неплох) есть, и все, что ли? Допустим, за последнее время написали кучу NoSQL баз - почему нет ни одной на хаскеле?
Edited 2012-10-12 14:00 (UTC)

[identity profile] iamjaph.livejournal.com 2012-10-18 06:58 am (UTC)(link)
:-)

Ну, это не NoSQL база. Сервер разрулививающий запросы на несколько Redis нод. Для запросов с множеством ключей, делит запросы на части, а потом собирает и объединяет ответы с каждой ноды.

https://github.com/kni/redis-sharding-hs

Это моя первая программа на haskell.
Написана как временная, пока не вышел Redis Cluster, но используется до сих пор.

[identity profile] levgem.livejournal.com 2012-10-12 06:37 pm (UTC)(link)
Не хочу огорчать, но мой опыт эрливидео четко говорит: опенсорсные коробочные продукты на хаскеле найдут своих пользователей. Обоих.

[identity profile] thesz.livejournal.com 2012-10-12 07:39 pm (UTC)(link)
Хаскель используют для внутрикорпоративных задач, очень его любят банки. Ибо сердито и весьма безопасно.

Базы данных... Пока не видел.

Есть игрушка: http://joyridelabs.de/game/code/

Пока всё. ;)

[identity profile] bydl0coder.livejournal.com 2012-10-12 07:41 pm (UTC)(link)
А почему? Вот реально, никак не ожидал, что apt-get install something_written_in_haskell принесет оконный менеджер, а не базу данных.

[identity profile] thesz.livejournal.com 2012-10-12 07:51 pm (UTC)(link)
Баз и так хватает, я так думаю.

[identity profile] metaclass.livejournal.com 2012-10-12 07:57 pm (UTC)(link)
С базами ситуация плохая. Им нужны зависимые типы, хаскель не спасает :)

[identity profile] thesz.livejournal.com 2012-10-12 08:19 pm (UTC)(link)
Мне сейчас надо продемонстрировать способность Хаскеля разбирать регулярные выражения на скорости в 10Гбайт в секунду, потом я подумаю насчёт БД. Или чего ещё.

[identity profile] bydl0coder.livejournal.com 2012-10-12 10:38 pm (UTC)(link)
А вот оконных менеджеров дефицит, ага. Ну напишите уже killer app, чтобы всякие глебы капустины замолчали.

[identity profile] thesz.livejournal.com 2012-10-12 10:48 pm (UTC)(link)
Хорошо. Постараюсь.

[identity profile] bydl0coder.livejournal.com 2012-10-12 11:16 pm (UTC)(link)
Нет, не надо киллер аппа. Я тут подумал, что практически все русские программисты в жж писали на хаскеле, а вот с этим надо что-то делать.

[identity profile] thesz.livejournal.com 2012-10-13 12:26 am (UTC)(link)
Не совсем понял мысль. Не возьмёте на себя труд объяснить мне подробней?

[identity profile] bydl0coder.livejournal.com 2012-10-13 01:33 am (UTC)(link)
"Довольно обидные ваши слова, папаша". Ну, я как придумал, мне это кажется очевидным.

[identity profile] bydl0coder.livejournal.com 2012-10-12 07:50 pm (UTC)(link)
Да я ж не спрашиваю, где мне искать работу, если вдруг научусь на хаскеле писать. Мне про коробки интересно - почему крестики, а не хаскель?

[identity profile] thesz.livejournal.com 2012-10-12 07:53 pm (UTC)(link)
Вот уж не знаю, почему плюсы. Наверное, никто не пытался.

Надо подумать.

[identity profile] inv2004.livejournal.com 2012-10-12 08:22 pm (UTC)(link)
Скачал, запустил, тормозит жутко, пришлось убить процесс, чтобы закрыть.

[identity profile] dmytrish.livejournal.com 2012-10-18 08:28 am (UTC)(link)
Это вы про РоЧе, или есть и другие примеры применения Хаскеля в банковской сфере?

[identity profile] thesz.livejournal.com 2012-10-18 11:04 am (UTC)(link)
Леннарт Аугустссон. В третьем, что ли, банке уже работает.