thedeemon: (Default)
[personal profile] thedeemon
Поразжигал немного в комментах у ребе Б. рознь к социальной группе "ленивые авторы языков". Чтобы не излагать свою позицию каждый раз заново, сохраню сюда.

Знаете, некоторые печальные даты надолго остаются в памяти людей: 11 сентября, 17 августа, 1917-й год, 1941-й. К ним стоит добавить 1995-й - год появления JavaScript, PHP, Ruby, ну и Java тоже. Кому-то захотелось по-быстрому добавить динамизма в веб-странички, и он за пару недель наговнякал интерпретатор, встроив его в браузер Netscape. Кому-то захотелось оживить свою домашнюю страничку, добавить счетчик посетителей, еще что-то, и он на коленке сделал такой вот изменятель страничек на стороне сервера. О больших проектах тогда никто не думал, personal home page назывался тот изменятель. А когда делаешь интерпретатор, проще всего сделать его на динамической типизации. Это банально очень просто. О системе типов вообще можно не задумываться, не говоря уже об их выводе. К сожалению, на фоне тогдашнего мейнстрима (Си, ранние плюсы, что там еще было?) эти скриптовые языки выглядели очень выигрышно, писать мелкие куски кода на них было намного проще. Что такое нормальная система типов тогда мало кто знал: хаскель был еще в пеленках, ML'и традиционно не выходили из университетов. Так что люди эти скрипты подхватили, стали добавлять все новые функции. Менять систему типов стало поздно. В итоге выросло то, что выросло. С тех пор одна масса людей занята тем, чтобы делать все более сложные интерпретаторы, которые бы не так тормозили, другая масса придумывает 121-й способ добавить в JS типы, а третья на динамических языках пишет и плачет в бложиках о том, как грустно им делается. И проблема не только и не столько в скорости, сколько в maintainability кода и усилиях на необходимые тестирование и отладку при росте проектов.

Единственная реальная причина появления динамически типизированных языков - лень и недальновидность авторов. Эволюционно динамические языки - тупиковая ветвь, хоть они и обречены рождаться вновь и вновь просто потому что их делать проще, а делать языки люди любят. Сегодняшняя популярность некоторых из них - случайность, исторический казус, следствие контраста между этими языками и мейнстримом начала 90-х. То, что много идиотов используют идиотские языки, говорит лишь о том, что идиотов много. Сегодня, когда есть языки с нормальной статической системой типов, никаких реальных преимуществ у динамической больше нет. Только я имею в виду действительно нормальные статически типизированные языки - как минимум с параметрическим и ad hoc полиморфизмами, с выводом типов. Не Си с джавой. Хаскель, окамл, скала - такого уровня. У этих конкретных языков могут быть свои проблемы, часто инфраструктурные, но речь сейчас не о них, речь о динамической vs. статической типизации в целом.

Date: 2012-10-11 04:30 pm (UTC)
From: [identity profile] alexandr alexeev (from livejournal.com)
Глупости вы все говорите. Наверное это очень удобно говорить, что на языках с динамической типизацией невозможно поддерживать проекты в которых больше 200 строк и пользоваться ЖЖ например.
Edited Date: 2012-10-11 04:31 pm (UTC)

Date: 2012-10-11 05:03 pm (UTC)
From: [identity profile] thedeemon.livejournal.com
Я не говорю невозможно. Люди умудряются и не такое делать. Я говорю о количестве требуемых усилий.

Date: 2012-10-17 08:03 am (UTC)
From: [identity profile] thinker8086.livejournal.com
Знаете, тут вспоминается известный тезис из ИБ: "Ни одна проблема безопасности не может быть решена чисто техническими средствами, но любая - может быть решена чисто административными".

Так и тут - конечно, похапе позволяет писать индусский код а-ля "str + 0" (типа конвертация строки в целое, ага), но реально все проблемы майнтайнабилити - это проблемы администрирования проекта.

Если продумана нормальная архитектура системы, осуществлено нормальное покрытие тестами, проводится нормальный code review, присутствует нормальное и по делу применение ООП - не вижу проблем с тем же PHP для решения довольно масштабных задач.

По крайней мере, цифра порядка 1млн посетителей в сутки, если речь о вебе, - не предел, и это ведь с довольно недорогой инфраструктурой.

А вот если система делается на коленке студентом-индусом даже без контроля версий - тут бывает всякое. Но, как правильно замечено, ещё года 3-4, и ровно то же самое будет и в Хаскеле. Просто пока студенту-индусу "слабо" написать там Hello World. Как только этот порог преодолеет критическая масса - язык ровно так же ни от чего не спасёт, т.к. эти самые средства, призванные спасать - будут тупо игнориться.

Date: 2012-10-17 08:30 am (UTC)
From: [identity profile] geekyfox.livejournal.com
ППКС

Date: 2012-10-17 09:01 am (UTC)
From: [identity profile] thedeemon.livejournal.com
Все же классы допустимых ошибок заметно отличаются, а это отражается на необходимых для тестов и рефакторинга усилиях. Да, можно решать вопросы административно - взять неограниченное число людей и неограниченное время, например. Японцы это любят, я слышал. Но если какие-то проверки и операции можно возложить на машину, зачем от этого так упорно отказываться? Нет ничего хорошего в том, что для того, чтобы узнать, что в программе оказался вызов не того метода или с неправильным количеством аргументов, нужно писать кучу тестов, регулярно их запускать и поддерживать в актуальном состоянии.

Что до хаскеля, то во-первых не думаю, что критическая масса условных индусов сможет преодолеть барьер этого конкретного языка в обозримом будущем, а во-вторых, да, там тоже можно писать с ошибками, но совсем другими ошибками, не такими тупыми. Код с тупыми ошибками там не компилируется. И чем сильнее система типов, тем больше тот класс ошибок, что язык не дает так просто допустить.

Вон в похапе две классические функции array_map($callback, $arr) и array_filter($arr, $callback) имеют противоположный порядок аргументов, провоцируя регулярно их путать. Зачем решать этот вопрос административными методами и тестами, когда банальная проверка типов этот вопрос полностью снимает?

Date: 2013-02-14 11:19 pm (UTC)
From: [identity profile] thinker8086.livejournal.com
>> И чем сильнее система типов, тем больше тот класс ошибок, что язык не дает так просто допустить.

Ещё раз - данный инструментарий, вполне вероятно, будет игнориться в случае отстуствия анальных кар, хотя, конечно, кое-что игнорить не получится. Не имею практического опыта на Хаскеле, могу заблуждаться в обе стороны.

Но вот будет ли тут кратный выигрыш в средней по отрасли эффективности разработки и отладки - сомневаюсь.

>> имеют противоположный порядок аргументов, провоцируя регулярно их путать.

1) Единственный тестовый прогон с включёнными предупреждениями всех уровней решает проблему обнаружения ошибки.

2) Нормальное IDE порядок параметров подскажет.

3) Да, меня тоже огорчает, что такие ошибки не ловятся автоматом. С другой стороны, пока мой опыт показывает, что такие и подобные ошибки виновны в сравнительно малом числе проблем. Косяки на уровне логики намного опаснее.

Profile

thedeemon: (Default)
Dmitry Popov

December 2025

S M T W T F S
 12 3456
789101112 13
14151617181920
21222324252627
28293031   

Most Popular Tags

Style Credit

Expand Cut Tags

No cut tags
Page generated Jan. 30th, 2026 07:27 pm
Powered by Dreamwidth Studios