Философия Unix — набор культурных норм и философских подходов к разработке программного обеспечения, основанных на опыте ведущих разработчиков операционной системы Unix. Существуют разные формулировки принципов, объясняющих нормы и традиции.
Три принципа Макилроя
Дуг Макилрой — изобретатель каналов Unix и один из основателей традиции Unix — обобщил философию следующим образом:
- пишите программы, которые делают что-то одно и делают это хорошо;
- пишите программы, которые бы работали вместе;
- пишите программы, которые бы поддерживали текстовые потоки, поскольку это универсальный интерфейс.
Обычно эти высказывания сводятся к одному «Делайте что-то одно, но делайте это хорошо». Из этих трёх принципов только третий является специфичным для Unix, хотя разработчики Unix чаще других акцентируют внимание на всех трёх принципах.
Принципы Ганкарца
В 1994 году Майк Ганкарц (англ. Mike Gancarz) объединил свой опыт работы над X Window System) с высказываниями из прений, в которых он участвовал со своими приятелями-программистами и людьми из других областей деятельности, так или иначе зависящих от Unix, и вывел в книге «Философия Unix» 9 основных принципов:
- красиво — небольшое;
- пусть каждая программа делает что-то одно, но хорошо;
- стройте прототип программы как можно раньше;
- предпочитайте переносимость эффективности;
- храните данные в простых текстовых файлах;
- извлекайте пользу из уже существующих программных решений;
- используйте сценарные языки для уменьшения трудозатрат и улучшения переносимости;
- избегайте пользовательских интерфейсов, ограничивающих возможности пользователя по взаимодействию с системой;
- делайте каждую программу «фильтром».
Менее важные 10 принципов не снискали всеобщего признания в качестве частей философии Unix и в некоторых случаях являлись предметом горячих споров (монолитное ядро против микроядра):
- позвольте пользователю настраивать окружение;
- делайте ядра операционной системы маленькими и легковесными;
- используйте нижний регистр и придерживайтесь кратких названий;
- не храните тексты программ в виде распечаток («спасите деревья!»);
- не сообщайте пользователю об очевидном («молчание — золото»);
- разбивайте сложные задачи на несколько простых, выполняемых параллельно («мыслите „параллельно“»);
- объединённые части целого есть нечто большее, чем просто их сумма;
- ищите 90-процентное решение;
- если можно не добавлять новую функциональность, не добавляйте её («чем хуже, тем лучше»);
- мыслите иерархически.
Тезисы Рэймонда
Эрик Рэймонд (англ. Eric S. Raymond) в книге «Искусство программирования в Unix» подытожил философию Unix как широко используемую инженерную философию «Делай это проще, глупец» (принцип KISS). Затем он описал, как эта обобщённая философия применима в качестве культурных норм Unix. И это несмотря на то, что несложно найти несколько нарушений в следующей текущей философии Unix:
- правило модульности: пишите простые части, соединяемые понятными интерфейсами;
- правило ясности: ясность лучше заумности;
- правило композиции: разрабатывайте программы так, чтобы их можно было соединить с другими программами;
- правило разделения: отделяйте правила (policy) от механизма (mechanism); отделяйте интерфейс от движка (engine);
- правило простоты: нацельтесь на простоту; добавляйте сложность, только где необходимо;
- правило экономности: пишите большую программу только когда другими средствами выполнить необходимую задачу не удастся;
- правило прозрачности: разрабатывайте прозрачные программы для облегчения последующего пересмотра и отладки;
- правило надёжности: надёжность — дитя прозрачности и простоты;
- правило представления: храните знания в данных так, чтобы логика программы была тупой и надёжной;
- правило наименьшего удивления: при разработке интерфейса всегда делайте так, чтобы привычные элементы интерфейса выполняли привычные функции;
- правило тишины: если программе нечего сказать, пусть лучше молчит;
- правило восстановления: если программа должна аварийно завершиться, делайте это шумно и как можно быстрее;
- правило экономии: время программиста дорого; сократите его, используя машинное время;
- правило генерации: избегайте ручного набора кода; при любом удобном случае пишите программы, которые бы писали программы;
- правило оптимизации: сначала — опытный образец, потом — «причесывание»; добейтесь стабильной работы, только потом оптимизируйте;
- правило многообразия: отвергайте все утверждения о «единственно правильном пути»;
- правило расширяемости: разрабатывайте для будущего — оно наступит быстрее, чем вы думаете;
Большинство из этих норм принимается вне сообщества Unix — даже если это было не так во времена, когда они впервые были применены в Unix, то впоследствии это стало так. К тому же много правил не являются уникальными или оригинальными для сообщества Unix. Тем не менее, приверженцы программирования в Unix склоняются к тому, чтобы принять сочетание этих идей в качестве основ для стиля Unix.
Цитаты
Некоторые широко известные высказывания, характеризующие культуру разработки Unix:
- «Unix прост. Но надо быть гением, чтобы понять его простоту» — Деннис Ритчи;
- «Unix не предназначен для ограждения своих пользователей от глупостей, поскольку это оградило бы их и от умных вещей» — Дуг Гвин;
- «Unix никогда не говорит „пожалуйста“» — Роб Пайк;
Критика
Философия UNIX критиковалась в книге «The UNIX-HATERS Handbook», изданной в начале 1990-х годов.
По мнению редакторов книги, подход Unix приводит к появлению решений, сделанных наспех, без должного продумывания архитектуры, после чего данные решения канонизируются (enshrined), то есть объявляются вечной классикой. Например, таким решением, по их мнению, являются lock files — временные файлы без содержимого, создаваемые как пометка того факта, что какая-то программа находится в процессе исполнения.
X Window System была подвергнута критике за отделение в ней механизма (engine) от политики (policy), что привело к отсутствию в UNIX стандарта на политики управления пользовательским интерфейсом и большим затруднениям при разработке приложений, использующих GUI.
NFS была подвергнута критике за изначально порочный подход к архитектуре — попытку создать stateless файл-сервер при том, что это принципиально невозможно. Когда же невозможность поддержки некоторых важных вещей стала очевидной, к NFS прикрутили «костыль» под названием процесса lockd.
Но, в то же время, критикуемые в этой книге подходы, начатые в *NIX, плавно обосновываются и в операционных системах семейств Windows и унаследованы macOS.
Ссылки