Філософія Unix, заснована Кеном Томпсоном, є набором культурних норм і філософських підходів до , модульної розробки програмного забезпечення. Вона ґрунтується на досвіді провідних розробників операційної системи Unix. Перші розробники Unix відіграли важливу роль у внесенні концепцій модульності та багаторазового використання у практику розробки програмного забезпечення, породивши рух . Згодом провідні розробники Unix (і програм, що працювали на ній) встановили набір норм для розробки програмного забезпечення. Ці норми стали настільки ж важливими та впливовими, як і сама технологія Unix та отримали назву «філософія Unix».
Філософія Unix наголошує на створенні простого, короткого, ясного, модульного та розширюваного коду, який може легко підтримуватися та перепрофілюватися іншими розробниками, а не тільки його творцями. Філософія Unix віддає перевагу композиційності на противагу .
Походження
Філософію Unix задокументував Дуглас Макілрой у журналі Bell System Technical 1978 року, яка складалась з 4 пунктів:
- Зробіть так, щоб кожна програма добре виконувала одну справу. Щоб виконати нову роботу, створюйте нові програми, а не ускладнюйте старі, додаючи новий функціонал.
- Очікуйте, що вихід кожної програми стане вхідним сигналом для іншої, поки невідомої, програми. Не захаращуйте вихідні дані сторонньою інформацією. Уникайте суворо стовпчастих або двійкових форматів введення. Не наполягайте на інтерактивному введенні.
- Проектуйте та створюйте програмне забезпечення, навіть операційні системи, які потрібно випробувати завчасно, в ідеалі протягом кількох тижнів. Не соромтеся видаляти незграбні частини та відновлювати їх.
- Не використовуйте некваліфіковану допомогу, щоб полегшити виконання завдання, краще скористайтесь інструментами, навіть якщо ви видалите деякі з них після того, як закінчите їх використання.
Пізніше узагальнив ці пункти у своїй книзі «A Quarter-Century of Unix» (1994):
- Пишіть програми, які роблять одну справу і роблять її добре.
- Пишіть програми з можливістю спільної роботи над ними.
- Пишіть програми для обробки текстових потоків, тому що це універсальний інтерфейс.
У своїй статті 1974 року, яка була відзначена численними нагородами, Річі та Томпсон цитують такі міркування щодо дизайну:
- Спростіть написання, тестування та запуск програм.
- Замініть пакетну обробку на інтерактивне використання.
- Економність та елегантність дизайну через обмеження розмірів («порятунок через страждання»).
- система: все програмне забезпечення Unix підтримується під Unix.
Майкл Шон Махоні
Середовище програмування UNIX
У своїй передмові до книги 1984 року Брайан Керніган і (обидва з Bell Labs) дають короткий опис дизайну Unix і філософії Unix:
Автори пишуть, що мета цієї книги — «повідомити про філософію програмування UNIX».
Розробка програм у середовищі UNIX
У жовтні 1984 року Браян Керніган і Роб Пайк опублікували статтю під назвою « Проектування програм у середовищі UNIX» . У цій статті вони критикують збільшення програмних опцій і функцій, які є в деяких нових системах Unix, таких як і System V, і пояснюють філософію програмних засобів Unix, кожен з яких виконує одну загальну функцію:
Автори порівнюють такі інструменти Unix, як cat, з більшими пакетами програм, які використовуються іншими системами.
Дуг Макілрой про програмування Unix
Макілрой, тодішній керівник дослідницького центру Bell Labs Computing Sciences і винахідник конвеєра, узагальнив філософію Unix таким чином:
Крім цих тверджень, він також наголосив на простоті та мінімалізмі в програмуванні Unix:
Макілрой також критикував сучасний Linux за наявність , зауважуючи, що «закохані шанувальники нагодували Linux смаколиками до невтішного стану ожиріння». Він порівнює це з попереднім підходом, використаним у Bell Labs при розробці та перегляді :
Робіть одну річ і робіть її добре
Як стверджує Макілрой, і, як правило, прийнято в Unix-спільноті, від програм Unix завжди очікується дотримання концепції DOTADIW («Do One Thing And Do It Well»). В Інтернеті мало інформації про абревіатуру DOTADIW, але вона докладно обговорювалась під час розробки нових операційних систем, особливо у спільноті Linux.
Патрік Фолькердінг, керівник проекту Slackware Linux, використав цей принцип проектування в критиці архітектури systemd, заявивши, що "спроба контролювати служби, розетки, пристрої, монтування тощо, все в межах одного демона стикається з концепцією Unix: «Робіть одну річ і робіть її добре».
17 правил Unix Еріка Реймонда
У своїй книзі «Мистецтво програмування Unix», яка була вперше опублікована в 2003 році Ерік С. Реймонд, американський програміст і прихильник відкритих кодів, підсумовує філософію Unix як принцип KISS «keep it simple, stupid». Він наводить ряд правил проектування:
- Створюйте модульні програми
- Пишіть читабельні програми
- Використовуйте композицію
- Пишіть прості програми
- Пишіть невеликі програми
- Пишіть прозорі програми
- Пишіть надійні програми
- За потреби ускладнюйте дані, а не програму
- Зважайте на очікувані знання потенційних користувачів
- Уникайте непотрібного виведення
- Пишіть програми, які дають збій, так, щоб їх було легко діагностувати
- Цінуйте час розробника, а не час комп'ютера
- Пишіть абстрактні програми, які генерують код, замість написання коду вручну
- Пишіть гнучкі та відкриті програми
- Зробіть розширюваними програму та її протоколи.
Майк Ганкарц: Філософія UNIX
У 1994 році Майк Ганкарц (член команди, яка розробила систему X Window), спирався на свій власний досвід роботи з Unix, а також на дискусії з колегами-програмістами та людьми в інших сферах, які залежали від Unix, щоб створити філософію UNIX, яка підсумовує це в дев'яти найважливіших принципах:
- Чим менше — тим краще.
- Кожна програма має добре виконувати лише одну роботу.
- Створіть прототип якомога швидше.
- Виберіть портативність, а не ефективність.
- Зберігайте дані в плоских текстових файлах .
- Використовуйте переваги програмного забезпечення на свою користь.
- Використовуйте скрипти середовища, щоб збільшити портативність.
- Уникайте неконтрольованих інтерфейсів користувача.
- Зробіть кожну програму фільтром .
«Чим гірше, тим краще»
припускає, що ключовою перевагою Unix було те, що він втілив філософію проектування, яку він назвав «чим гірше, тим краще», в якій простота інтерфейсу та реалізації важливіші за будь-які інші атрибути системи, включаючи коректність, послідовність і повноту. Габріель стверджує, що цей стиль дизайну має ключові еволюційні переваги, хоча він ставить під сумнів якість деяких результатів.
Наприклад, на початку Unix використовував монолітне ядро (це означає, що процеси користувача здійснювали системні виклики у стеку користувача). Якщо сигнал був доставлений процесу, коли він був заблокований під час тривалого (введення-виведення) в ядрі, що робити? Чи слід відкласти сигнал, можливо, на тривалий час (можливо, на невизначений термін), поки введення/виведення не буде завершено? Обробник сигналів не може бути виконаний, коли процес перебував у режимі ядра з конфіденційними даними ядра в стеку. Чи повинне ядро скасувати системний виклик і зберегти його для повторного відтворення та перезапуску пізніше, припускаючи, що обробник сигналу завершиться успішно?
У цих випадках Кен Томпсон і Денніс Річі віддавали перевагу простоті, а не досконалості. Система Unix іноді поверталася раніше після системного виклику з повідомленням про те, що вона нічого не зробила — «Перерваний системний виклик» або помилка номер 4 (EINTR
) у сучасних системах. Звичайно, виклик був перерваний, щоб викликати обробника сигналів. Це могло статися лише для кількох тривалих системних викликів, таких як read()
, write()
, open()
і select()
. Позитивним є те, що це зробило систему введення-виводу в рази простішою для розробки та розуміння. Більшість користувацьких програм жодним чином від цього не постраждали б, оскільки вони не обробляли інших сигналів окрім SIGINT
і відразу б зупинили виконання, якщо б хоч один був піднятий[]. Для кількох інших програм, таких як програмні середовища або текстові редактори, які реагують на натискання клавіш керування завданням, можна було б додати невеликі обгортки до системних викликів, щоб негайно повторити виклик, якщо виникла помилка EINTR.
Таким чином, проблему було вирішено простим способом.
Критика
У статті 1981 року під назвою "Правда про Unix: інтерфейс користувача жахливий " опублікованій в Datamation, Дон Норман критикував філософію дизайну Unix за відсутність інтерфейсу користувача. Пишучи зі свого досвіду в когнітивній науці та з точки зору тодішньої філософії , він зосередився на тому, як кінцеві користувачі розуміють і формують особисту когнітивну модель систем, або, у випадку з Unix, не можуть її зрозуміти, і як результат, стають причиною катастрофічних помилок (наприклад, втрата годинної роботи).
Додаткова література
Примітки
- Raymond, Eric S. (2004). Basics of the Unix Philosophy. The Art of Unix Programming. Addison-Wesley Professional. ISBN . Процитовано 1 листопада 2016.
- Doug McIlroy, E. N. Pinson, B. A. Tague (8 липня 1978). Unix Time-Sharing System: Foreword. The Bell System Technical Journal. Bell Laboratories: 1902—1903.
- . Архів оригіналу за 26 січня 2021. Процитовано 26 серпня 2021.
ACM Programming Systems and Languages Paper Award
- Dennis Ritchie; Ken Thompson (1974), The UNIX time-sharing system (PDF), Communications of the ACM, 17 (7): 365—375, doi:10.1145/361011.361061
- Kernighan, Brian W. Pike, Rob. The UNIX Programming Environment. 1984. viii
- Rob Pike; Brian W. Kernighan (October 1984). Program Design in the UNIX Environment (PDF).
- Dennis Ritchie (1984), The Evolution of the UNIX Time-Sharing System (PDF), , 63 (8): 1577—1593, doi:10.1002/j.1538-7305.1984.tb00054.x
- Douglas McIlroy. Remarks for Japan Prize award ceremony for Dennis Ritchie, May 19, 2011, Murray Hill, NJ (PDF). Процитовано 19 червня 2014.
- Bill McGonigle. Ancestry of Linux — How the Fun Began (2005). Процитовано 19 червня 2014.
- Interview with Patrick Volkerding of Slackware. linuxquestions.org. 7 червня 2012. Процитовано 24 жовтня 2015.
- Raymond, Eric (19 вересня 2003). The Art of Unix Programming. Addison-Wesley. ISBN . Процитовано 9 лютого 2009.
- Raymond, Eric (19 вересня 2003). The Unix Philosophy in One Lesson. The Art of Unix Programming. Addison-Wesley. ISBN . Процитовано 9 лютого 2009.
- Norman, Don (1981). The truth about Unix: The user interface is horrid (PDF). Datamation. Т. 27, № 12.
Посилання
- Середовище програмування Unix, Брайан Керніган і Роб Пайк, 1984
- Розробка програми в середовищі UNIX — стаття Пайка і Кернігана, яка передувала книзі.
- Нотатки щодо програмування на C, Роб Пайк, 21 вересня 1989 року
- Чверть століття Unix, Пітер Х. Салус, Аддісон-Веслі, 31 травня 1994 р. ()
- Філософія — з «Мистецтво програмування Unix», Ерік С. Реймонд, Аддісон-Веслі, 17 вересня 2003 р. ()
- Остаточний звіт проекту Multics Kernel Design від М. Д. Шредера, Д. Д. Кларка, Дж. Х. Зальцера та Д. Х. Уеллса, 1977 р.
- Філософія UNIX, Майк Ганкарц,
Посилання
- Основи філософії Unix — Catb.org
- Філософія Unix: Короткий вступ — The Linux Information Project (LINFO)
- Чому філософія Unix все ще має значення
Вікіпедія, Українська, Україна, книга, книги, бібліотека, стаття, читати, завантажити, безкоштовно, безкоштовно завантажити, mp3, відео, mp4, 3gp, jpg, jpeg, gif, png, малюнок, музика, пісня, фільм, книга, гра, ігри, мобільний, телефон, android, ios, apple, мобільний телефон, samsung, iphone, xiomi, xiaomi, redmi, honor, oppo, nokia, sonya, mi, ПК, web, Інтернет
Filosofiya Unix zasnovana Kenom Tompsonom ye naborom kulturnih norm i filosofskih pidhodiv do modulnoyi rozrobki programnogo zabezpechennya Vona gruntuyetsya na dosvidi providnih rozrobnikiv operacijnoyi sistemi Unix Pershi rozrobniki Unix vidigrali vazhlivu rol u vnesenni koncepcij modulnosti ta bagatorazovogo vikoristannya u praktiku rozrobki programnogo zabezpechennya porodivshi ruh Zgodom providni rozrobniki Unix i program sho pracyuvali na nij vstanovili nabir norm dlya rozrobki programnogo zabezpechennya Ci normi stali nastilki zh vazhlivimi ta vplivovimi yak i sama tehnologiya Unix ta otrimali nazvu filosofiya Unix Ken Tompson i Dennis Richi klyuchovi prihilniki filosofiyi Unix Filosofiya Unix nagoloshuye na stvorenni prostogo korotkogo yasnogo modulnogo ta rozshiryuvanogo kodu yakij mozhe legko pidtrimuvatisya ta pereprofilyuvatisya inshimi rozrobnikami a ne tilki jogo tvorcyami Filosofiya Unix viddaye perevagu kompozicijnosti na protivagu PohodzhennyaFilosofiyu Unix zadokumentuvav Duglas Makilroj u zhurnali Bell System Technical 1978 roku yaka skladalas z 4 punktiv Zrobit tak shob kozhna programa dobre vikonuvala odnu spravu Shob vikonati novu robotu stvoryujte novi programi a ne uskladnyujte stari dodayuchi novij funkcional Ochikujte sho vihid kozhnoyi programi stane vhidnim signalom dlya inshoyi poki nevidomoyi programi Ne zaharashujte vihidni dani storonnoyu informaciyeyu Unikajte suvoro stovpchastih abo dvijkovih formativ vvedennya Ne napolyagajte na interaktivnomu vvedenni Proektujte ta stvoryujte programne zabezpechennya navit operacijni sistemi yaki potribno viprobuvati zavchasno v ideali protyagom kilkoh tizhniv Ne soromtesya vidalyati nezgrabni chastini ta vidnovlyuvati yih Ne vikoristovujte nekvalifikovanu dopomogu shob polegshiti vikonannya zavdannya krashe skoristajtes instrumentami navit yaksho vi vidalite deyaki z nih pislya togo yak zakinchite yih vikoristannya Piznishe uzagalniv ci punkti u svoyij knizi A Quarter Century of Unix 1994 Pishit programi yaki roblyat odnu spravu i roblyat yiyi dobre Pishit programi z mozhlivistyu spilnoyi roboti nad nimi Pishit programi dlya obrobki tekstovih potokiv tomu sho ce universalnij interfejs U svoyij statti 1974 roku yaka bula vidznachena chislennimi nagorodami Richi ta Tompson cituyut taki mirkuvannya shodo dizajnu Sprostit napisannya testuvannya ta zapusk program Zaminit paketnu obrobku na interaktivne vikoristannya Ekonomnist ta elegantnist dizajnu cherez obmezhennya rozmiriv poryatunok cherez strazhdannya sistema vse programne zabezpechennya Unix pidtrimuyetsya pid Unix Vsya filosofiya UNIX shozhe u tomu shob trimatisya podali vid asemblera Majkl Shon MahoniSeredovishe programuvannya UNIXU svoyij peredmovi do knigi 1984 roku Brajan Kernigan i obidva z Bell Labs dayut korotkij opis dizajnu Unix i filosofiyi Unix Rob Pajk spivavtor The UNIX Programming Environment Nezvazhayuchi na te sho sistema UNIX predstavlyaye ryad innovacijnih program ta metodiv zhodna programa chi ideya ne robit yiyi efektivnoyu Natomist te sho robit yiyi efektivnoyu ce pidhid do programuvannya filosofiya vikoristannya komp yutera Hocha cyu filosofiyu ne mozhna zapisati v odnomu rechenni v yiyi osnovi lezhit ideya pro te sho sila sistemi bilshoyu miroyu zalezhit vid vidnosin mizh programami nizh vid samih program Bagato program UNIX roblyat dosit trivialni rechi vlasnimi silami ale u poyednanni z inshimi programami stayut zagalnimi ta korisnimi instrumentami Avtori pishut sho meta ciyeyi knigi povidomiti pro filosofiyu programuvannya UNIX Rozrobka program u seredovishi UNIXBrayan Kernigan dovgo pisav pro filosofiyu Unix U zhovtni 1984 roku Brayan Kernigan i Rob Pajk opublikuvali stattyu pid nazvoyu Proektuvannya program u seredovishi UNIX U cij statti voni kritikuyut zbilshennya programnih opcij i funkcij yaki ye v deyakih novih sistemah Unix takih yak i System V i poyasnyuyut filosofiyu programnih zasobiv Unix kozhen z yakih vikonuye odnu zagalnu funkciyu Bilshist mozhlivostej operacijnoyi sistemi UNIX obumovleni stilem rozrobki program yakij robit programi prostimi u vikoristanni i sho vazhlivishe legko poyednuyutsya z inshimi programami Cej stil buv nazvanij vikoristannyam programnih instrumentiv i vin bilshoyu miroyu zalezhit vid togo yak programi vpisuyutsya v seredovishe programuvannya i yak mozhut buti vikoristani z inshimi programami nizh vid togo yak voni rozrobleni vseredini Cej stil buv zasnovanij na vikoristanni instrumentiv vikoristannya program okremo abo v kombinaciyi dlya vikonannya roboti zamist togo shob robiti ce vruchnu za dopomogoyu monolitnih samodostatnih pidsistem abo specializovanih odnorazovih program Avtori porivnyuyut taki instrumenti Unix yak cat z bilshimi paketami program yaki vikoristovuyutsya inshimi sistemami Dizajn cat tipovij bilshist program UNIX vin realizuye odnu prostu ale zagalnu funkciyu yaka mozhe buti vikoristana u bagatoh riznih dodatkah Inshi komandi vikoristovuyut inshi funkciyi Napriklad isnuyut okremi komandi dlya zavdan fajlovoyi sistemi taki yak perejmenuvannya fajliv vidalennya abo viznachennya yih rozmiru Inshi sistemi natomist poyednuyut yih u odnu komandu fajlova sistema z vnutrishnoyu strukturoyu ta vlasnoyu movoyu komand Prikladom mozhe buti programa kopiyuvannya fajliv PIP yaka vikoristovuyetsya v takih operacijnih sistemah yak CP M abo RSX 11 Takij pidhid ne obov yazkovo girshij chi krashij ale vin bezperechno superechit filosofiyi UNIX Dug Makilroj pro programuvannya UnixDuglas Makilroj livoruch z Dennisom Richi Makilroj todishnij kerivnik doslidnickogo centru Bell Labs Computing Sciences i vinahidnik konveyera uzagalniv filosofiyu Unix takim chinom Ce filosofiya Unix Pishit programi yaki vikonuyut odnu robotu ta roblyat yiyi dobre Pishit programi dlya mozhlivosti spilnoyi roboti nad nimi Pishit programi dlya roboti zi standartnimi potokami tomu sho ce universalnij interfejs Krim cih tverdzhen vin takozh nagolosiv na prostoti ta minimalizmi v programuvanni Unix Ponyattya hitromudri i krasivi skladnosti ce majzhe oksimoron Unix programisti zmagayutsya odin z odnim za zvannya prostogo i krasivogo cej moment mayetsya na uvazi u cih pravilah ale jogo varto ozvuchiti Makilroj takozh kritikuvav suchasnij Linux za nayavnist zauvazhuyuchi sho zakohani shanuvalniki nagoduvali Linux smakolikami do nevtishnogo stanu ozhirinnya Vin porivnyuye ce z poperednim pidhodom vikoristanim u Bell Labs pri rozrobci ta pereglyadi Vse bulo malenkim i moye serce zavmiraye koli bachu rozmiri Linux sogodni Storinka teper nagaduye nevelikij tom z tisyacheyu opcij Mi sidili i dumali Sho mi mozhemo vidaliti Chomu cej funkcional znahoditsya tam Chasto ce vidbuvayetsya tomu sho v bazovomu dizajni ye yakijs nedolik Zamist togo shob dodavati opciyu podumajte pro te sho zmusilo vas dodati cyu opciyu Robit odnu rich i robit yiyi dobreYak stverdzhuye Makilroj i yak pravilo prijnyato v Unix spilnoti vid program Unix zavzhdi ochikuyetsya dotrimannya koncepciyi DOTADIW Do One Thing And Do It Well V Interneti malo informaciyi pro abreviaturu DOTADIW ale vona dokladno obgovoryuvalas pid chas rozrobki novih operacijnih sistem osoblivo u spilnoti Linux Patrik Folkerding kerivnik proektu Slackware Linux vikoristav cej princip proektuvannya v kritici arhitekturi systemd zayavivshi sho sproba kontrolyuvati sluzhbi rozetki pristroyi montuvannya tosho vse v mezhah odnogo demona stikayetsya z koncepciyeyu Unix Robit odnu rich i robit yiyi dobre 17 pravil Unix Erika RejmondaU svoyij knizi Mistectvo programuvannya Unix yaka bula vpershe opublikovana v 2003 roci Erik S Rejmond amerikanskij programist i prihilnik vidkritih kodiv pidsumovuye filosofiyu Unix yak princip KISS keep it simple stupid Vin navodit ryad pravil proektuvannya Stvoryujte modulni programi Pishit chitabelni programi Vikoristovujte kompoziciyu Pishit prosti programi Pishit neveliki programi Pishit prozori programi Pishit nadijni programi Za potrebi uskladnyujte dani a ne programu Zvazhajte na ochikuvani znannya potencijnih koristuvachiv Unikajte nepotribnogo vivedennya Pishit programi yaki dayut zbij tak shob yih bulo legko diagnostuvati Cinujte chas rozrobnika a ne chas komp yutera Pishit abstraktni programi yaki generuyut kod zamist napisannya kodu vruchnu Pishit gnuchki ta vidkriti programi Zrobit rozshiryuvanimi programu ta yiyi protokoli Majk Gankarc Filosofiya UNIXU 1994 roci Majk Gankarc chlen komandi yaka rozrobila sistemu X Window spiravsya na svij vlasnij dosvid roboti z Unix a takozh na diskusiyi z kolegami programistami ta lyudmi v inshih sferah yaki zalezhali vid Unix shob stvoriti filosofiyu UNIX yaka pidsumovuye ce v dev yati najvazhlivishih principah Chim menshe tim krashe Kozhna programa maye dobre vikonuvati lishe odnu robotu Stvorit prototip yakomoga shvidshe Viberit portativnist a ne efektivnist Zberigajte dani v ploskih tekstovih fajlah Vikoristovujte perevagi programnogo zabezpechennya na svoyu korist Vikoristovujte skripti seredovisha shob zbilshiti portativnist Unikajte nekontrolovanih interfejsiv koristuvacha Zrobit kozhnu programu filtrom Chim girshe tim krashe pripuskaye sho klyuchovoyu perevagoyu Unix bulo te sho vin vtiliv filosofiyu proektuvannya yaku vin nazvav chim girshe tim krashe v yakij prostota interfejsu ta realizaciyi vazhlivishi za bud yaki inshi atributi sistemi vklyuchayuchi korektnist poslidovnist i povnotu Gabriel stverdzhuye sho cej stil dizajnu maye klyuchovi evolyucijni perevagi hocha vin stavit pid sumniv yakist deyakih rezultativ Napriklad na pochatku Unix vikoristovuvav monolitne yadro ce oznachaye sho procesi koristuvacha zdijsnyuvali sistemni vikliki u steku koristuvacha Yaksho signal buv dostavlenij procesu koli vin buv zablokovanij pid chas trivalogo vvedennya vivedennya v yadri sho robiti Chi slid vidklasti signal mozhlivo na trivalij chas mozhlivo na neviznachenij termin poki vvedennya vivedennya ne bude zaversheno Obrobnik signaliv ne mozhe buti vikonanij koli proces perebuvav u rezhimi yadra z konfidencijnimi danimi yadra v steku Chi povinne yadro skasuvati sistemnij viklik i zberegti jogo dlya povtornogo vidtvorennya ta perezapusku piznishe pripuskayuchi sho obrobnik signalu zavershitsya uspishno U cih vipadkah Ken Tompson i Dennis Richi viddavali perevagu prostoti a ne doskonalosti Sistema Unix inodi povertalasya ranishe pislya sistemnogo vikliku z povidomlennyam pro te sho vona nichogo ne zrobila Perervanij sistemnij viklik abo pomilka nomer 4 EINTR u suchasnih sistemah Zvichajno viklik buv perervanij shob viklikati obrobnika signaliv Ce moglo statisya lishe dlya kilkoh trivalih sistemnih viklikiv takih yak read write open i select Pozitivnim ye te sho ce zrobilo sistemu vvedennya vivodu v razi prostishoyu dlya rozrobki ta rozuminnya Bilshist koristuvackih program zhodnim chinom vid cogo ne postrazhdali b oskilki voni ne obroblyali inshih signaliv okrim SIGINT i vidrazu b zupinili vikonannya yaksho b hoch odin buv pidnyatij kudi Dlya kilkoh inshih program takih yak programni seredovisha abo tekstovi redaktori yaki reaguyut na natiskannya klavish keruvannya zavdannyam mozhna bulo b dodati neveliki obgortki do sistemnih viklikiv shob negajno povtoriti viklik yaksho vinikla pomilka EINTR Takim chinom problemu bulo virisheno prostim sposobom KritikaU statti 1981 roku pid nazvoyu Pravda pro Unix interfejs koristuvacha zhahlivij opublikovanij v Datamation Don Norman kritikuvav filosofiyu dizajnu Unix za vidsutnist interfejsu koristuvacha Pishuchi zi svogo dosvidu v kognitivnij nauci ta z tochki zoru todishnoyi filosofiyi vin zoseredivsya na tomu yak kincevi koristuvachi rozumiyut i formuyut osobistu kognitivnu model sistem abo u vipadku z Unix ne mozhut yiyi zrozumiti i yak rezultat stayut prichinoyu katastrofichnih pomilok napriklad vtrata godinnoyi roboti Dodatkova literaturaRozrobka programnogo zabezpechennya Princip KISS Hakerska etika Girshe tim krashePrimitki Raymond Eric S 2004 Basics of the Unix Philosophy The Art of Unix Programming Addison Wesley Professional ISBN 0 13 142901 9 Procitovano 1 listopada 2016 Doug McIlroy E N Pinson B A Tague 8 lipnya 1978 Unix Time Sharing System Foreword The Bell System Technical Journal Bell Laboratories 1902 1903 Arhiv originalu za 26 sichnya 2021 Procitovano 26 serpnya 2021 ACM Programming Systems and Languages Paper Award Dennis Ritchie Ken Thompson 1974 The UNIX time sharing system PDF Communications of the ACM 17 7 365 375 doi 10 1145 361011 361061 Kernighan Brian W Pike Rob The UNIX Programming Environment 1984 viii Rob Pike Brian W Kernighan October 1984 Program Design in the UNIX Environment PDF Dennis Ritchie 1984 The Evolution of the UNIX Time Sharing System PDF 63 8 1577 1593 doi 10 1002 j 1538 7305 1984 tb00054 x Douglas McIlroy Remarks for Japan Prize award ceremony for Dennis Ritchie May 19 2011 Murray Hill NJ PDF Procitovano 19 chervnya 2014 Bill McGonigle Ancestry of Linux How the Fun Began 2005 Procitovano 19 chervnya 2014 Interview with Patrick Volkerding of Slackware linuxquestions org 7 chervnya 2012 Procitovano 24 zhovtnya 2015 Raymond Eric 19 veresnya 2003 The Art of Unix Programming Addison Wesley ISBN 0 13 142901 9 Procitovano 9 lyutogo 2009 Raymond Eric 19 veresnya 2003 The Unix Philosophy in One Lesson The Art of Unix Programming Addison Wesley ISBN 0 13 142901 9 Procitovano 9 lyutogo 2009 Norman Don 1981 The truth about Unix The user interface is horrid PDF Datamation T 27 12 PosilannyaSeredovishe programuvannya Unix Brajan Kernigan i Rob Pajk 1984 Rozrobka programi v seredovishi UNIX stattya Pajka i Kernigana yaka pereduvala knizi Notatki shodo programuvannya na C Rob Pajk 21 veresnya 1989 roku Chvert stolittya Unix Piter H Salus Addison Vesli 31 travnya 1994 r ISBN 0 201 54777 5 Filosofiya z Mistectvo programuvannya Unix Erik S Rejmond Addison Vesli 17 veresnya 2003 r ISBN 0 13 142901 9 Ostatochnij zvit proektu Multics Kernel Design vid M D Shredera D D Klarka Dzh H Zalcera ta D H Uellsa 1977 r Filosofiya UNIX Majk Gankarc ISBN 1 55558 123 4PosilannyaOsnovi filosofiyi Unix Catb org Filosofiya Unix Korotkij vstup The Linux Information Project LINFO Chomu filosofiya Unix vse she maye znachennya