Баг

Материал из Неолурк, народный Lurkmore
Перейти к навигации Перейти к поиску
Топ багов, которые сделали видеоигры лучше
Тестировщик охотится за багами в готовом проекте
Историки до сих пор спорят, как называть эту войну: третья космическая (или четвертая), а может, Первая межзвездная. Мы же называем ее просто войной с багами
— Starship troopers

Баг (от англ. bug — жук, мелкое насекомое, букашка, жучок, паук) — некая ошибка, которая встречается в определенном программном обеспечении. Термин распространён в сообществе программистов. Бывают баги разной степени критичности, некоторые могут создавать лишь небольшие визуальные неудобства, иные же делают программу полностью неработоспособной. Разработка современного программного обеспечения во многом построена на постоянном тестировании каждого фрагмента кода, так как в огромной программе на миллионы строчек оказывается очень тяжело, а то и невозможно, определить конкретную проблему, если она будет обнаружена только спустя какое-то время после внесения.

Чаще всего на сленге означает неясного происхождения ошибку, неисправность, сбой в устройстве. В этом смысле слово употреблялось еще в XIX в. телеграфистами и электротехниками. В современном сленге чаще означает ошибку в программе. Считается, что этот смысл слово приобрело благодаря обнаруженной в 1947 ошибке в работе электромеханической ЭВМ, которую вызвал попавший в реле и замкнувший контакты мотылёк. Несчастное погибшее насекомое было вклеено в рабочий журнал скотчем с иронической записью «первый подлинный случай обнаружения жучка»[1]. С той поры утекло много воды, реле в современных ЭВМ встречаются редко, но ошибки и сбои в программах так и зовутся «багами», а процесс их обнаружения и устранения называется иногда «debugging».

Следует отличать баг от глюка, который есть не что иное, как симптом бага, вызывающий у юзера нервно-истерическую реакцию. Также имеется производное от «баг» понятие «бага». «Бага» — то же самое, что и «баг», только женского рода. Считается, что фиксить «багу» приятнее, чем «баг».

Что ещё почитать[править]

Описание[править]

Понятие бага появилось еще во время отладки средств связи в XX веке, где багами (жуками) назывались определенные помехи при передаче сообщений (для решения которых были введены специальные методики кодирования, позволяющие исправлять одну ошибку). В середине XX века внутри тогда еще лампового компьютера были найдены останки бабочки, которая залетела в аппарат и вызвало короткое замыкание, о чем была сделана заметка, что был найден настоящий жук (real bug).

Как правило баги не являются критичными и их наличие не приводит к моментальному завершению исполнения программы. Тем не менее, некоторые баги могут сильно мешать корректной работе, искажать результаты (которые будут неполными или вообще неверными).

Баги можно разделить по степени серьезности:

  • критические — баги, которые полностью мешают исполнению какой-либо программы, работе сайта. Например, для участия на сайте необходимо пройти авторизацию, но форма авторизации настроена некорректно, и фактически зайти на сайт невозможно. Являются приоритетом для исправления техническим персоналом.
  • серьезные — например, не отображаются картинки в определенном интерфейсе, при этом сама программа работает и пользоваться ей в целом можно.
  • мелкие — не работает определенный второстепенный функционал, который не влияет на функции программы, например не показываются сведения о программе.
  • незначительные — некие мелкие ошибки, которые сложно даже и заметить. Исправляются в порядке очереди.

Есть распространенная фраза «это не баг, это фича», так говорится про ситуацию, когда определенный баг был в принципе не предусмотрен, но конкретный эффект этого бага оказался на самом деле полезен или понравился пользователям, так что вместо исправления ошибки было принято решение оставить все, как есть.

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

История[править]

И здесь они тоже водятся

Версии:

  • По легенде, 9 сентября 1945 года учёные Гарвардского университета, тестировавшие вычислительную машину Mark II Aiken Relay Calculator, нашли мотылька, застрявшего между контактами электромеханического реле, и Грейс Хоппер сгоряча сморозила сей термин. Извлечённое насекомое было вклеено в технический дневник с сопроводительной надписью: «First actual case of bug being found». Этот забавный факт положил начало использованию слова «баг» в значении «ашипка».
  • Есть и версия, по которой термин родился гораздо раньше, когда Эдисон искал таракана в фонографе. Но там его не было, баг был в самом устройстве!
  • По другой версии, виной тому случай, произошедший 9 сентября 1947, а не 1945 года. Слово «bug» в современном значении употреблялось задолго до этого. Так, в течение Второй мировой войны словом «bugs» назывались проблемы с радарной электроникой.
  • По самой приземленной версии, слово произошло от английского глагола to bug (пилить, беспокоить, стоять над душой), или бранного слова bugger (черт побери).

Впоследствии слово баг было перенято всеми хоть каким-то образом приобщенными к компьютерам людьми и его значение в каждом конкретном случае стало разным. Но понятие ашипки по-прежнему является обобщающим для всех этих значений, алсо, 9 сентября отмечается День тестировщика.

Откуда берутся[править]

  • Ошибка. Не продумал алгоритм, сделал логическую ошибку, просто опечатался[2][3], плохо знает особенности использованного языка или инструментов. Бывает со всеми, поэтому: тесты и ещё раз тесты.
    • Кстати, современные ЯП во многом продвинулись в «защите от дурака»: наиболее опасные в этом плане приведение типов, управление памятью и работу с указателями стараются либо переложить на компилятор, либо обложить проверками в рантайме, либо сильно ограничить. Программисты старой школы часто недовольны, ибо эти меры порой снижают производительность или не дают выполнить привычные им трюки. А то, что иначе приходится попеременно бороться то с утечкой памяти, то с потерянными указателями, то с развалившимся стеком — в этом своя романтика, вам салагам не понять.
  • Плохая постановка задачи. От «мне никто не сказал, что оно должно останавливаться, если нажата левая педаль» до «вы же сами просили, чтобы по нажатии кнопки оно получало задание „убить всех людей“. В ТЗ прямо так и написано».
  • Трюкачество. Бывают очень неочевидные способы решения конкретной задачи, которые могут породить не менее неочевидные побочные эффекты. С другой стороны, без трюков порой решить задачу либо невозможно, либо слишком долго. Вот только если трюк не слишком широко распространён, когда код начнёт править другой программист (или ты же, но через полгода-год), он, скорее всего, неправильно поймёт, как это работает, и всё сломает. Наиболее известный трюк, использовавшийся в разработке игр в начале 2000-х — Быстрый обратный квадратный корень.
  • Использование недокументированных возможностей. Во многих языках программирования, библиотеках и даже «железе» есть средства, которые еще не вошли в стандарт и не факт, что войдут. Однако некоторые программисты ими пользуются, уж очень бывает заманчиво. Если потом использованная неявная возможность будет изменена или вовсе отключена, то последствия будут печальными.
    • Хуже того, в современных языках программирования есть такая засада, как неопределённое поведение — когда в спецификации прямо пишут, что если вы сделаете так-то и так-то, то мы не знаем, что будет. Программа может отработать его так, может эдак; может под отладчиком делать одно, а в продакшне — совершенно противоположное. А может вломиться к вам в дом среди ночи и убить вашу собаку[4].
  • «Велосипедостроение». Когда вместо широко известных и многократно оттестированных инструментов используется самоделка, собранная на коленке.
  • Ошибка в использованных инструментах, созданных кем-то другим — противоположная ситуация. Все мы не идеальны и кто-то там, кто писал какую-нибудь нужную библиотеку тоже мог накосячить. Можно оправдывать все баги плохими библиотеками. Как правило, если библиотекой пользуются не 3,5 программиста, а множество людей по всему миру, и достаточно давно, большинство багов либо исправлены, либо хорошо задокументированы.
    • Бывает, что баги в подобных библиотеках не исправляют не потому, что разработчики библиотеки такие ленивые, а потому, что пока они эту ошибку нашли, множество людей стали пользоваться ей как багофичей, и если её исправить сейчас, у них всё поломается.
    • Взаимодействие между сторонним софтом тоже в это умеет, когда каждая программа по отдельности работает прекрасно, а при совместной работе начинаются танцы с бубном. Взаимодействие разных версий одного и того же софта между собой — отдельная песня, исполняемая в си-бемоль-миноре.
  • Использование инструмента не по назначению. Начал забивать гвозди микроскопом — ой, стекляшки во все стороны сыплются! Использую СУБД для управления бизнес-логикой — и что-то программа стала жрать память как не в себя. Как правило, подобное начинается с того, что нужно реализовать какую-то мелочь, искать для этого специализированный инструмент лень. И потом хватаешься за голову, обнаружив, что весь проект работает на костылях, для этого не предназначенных.
    • С другой стороны, бывает, когда вроде бы инструмент используется по назначению, но авторы не подумали, что он будет использоваться так. Помните знаменитый «баг тысячелетия»? Всего лишь в 1970-80 программисты считали, что их детище не проживёт нескольких лет, будучи заменённым на что-то более совершенное, а память надо экономить прямо сейчас: счёт порой шёл на байты. А к концу 1990-х на вылавливание и исправление «коротких» дат потратили огромные деньги и всё равно 2000-го года ждали с замиранием сердца: а вдруг где-то вылезет! Или пренебрежение проверкой на граничные условия — ну не подумал кто-то, что кто-то захочет открыть вашей программой файл больше 255 гигабайт или задать отрицательную высоту какого-нибудь элемента. Часто такие баги становятся эксплойтами.
  • Плохо налаженное взаимодействие между разработчиками. Когда разработка ведётся по принципу письма Дяди Фёдора.
  • Спешка. Хороший руководитель разработки грамотно разобьёт задачу на этапы, расставит приоритеты и позаботится о средствах на случай, если что-то пойдёт не так (нанять больше разработчиков, отдать на аутсорс, отказаться от фичи или перенести её на следующую версию и т. д.) заранее. Плохой руководитель 80 % времени будет заниматься механической работой: следить, чтоб не опаздывали и не занимались посторонними делами, устраивать совещания с power point-презентациями, а к концу срока узнает, что проект едва ли готов наполовину, нанимать новых разработчиков или отдавать на аутсорс поздно — просто не успеем ввести их в курс дела и перераспределить задачи, резать фичи нельзя, так как их уже анонсировали и разрекламировали, переносить срок — тоже, приходится заставлять работать сверхурочно, пренебрегать тестами и вообще делать абы как.

Легенды[править]

Один баг. Но какой!

Самый известный баг тысячелетия назывался «Ошибка 2000 года», или Y2K Error. Суть дефекта состояла в том, что государственные и военные конторы в Пендостане и Европах имели на вооружении древние софтины, написанные бородатыми студентами из НИИ. Это древнее ПО хранило только две последние цифры из номера года (например, 98 вместо 1998). При наступлении 2000 года эти софтины должны были записать текущий год как 00, что вызвало бы Апокалипсис, ядерную войну и приход Большого Волосатого Друга. Эта тема стала подниматься говножурналистами по говноящику во всяких говногазетёнках (пример), что вызвало панику у домохозяек и много красных задниц в программистских конторах. После этого началась война лихорадочных правок существующих софтин. Багу искали даже там, где её физически не могло быть. Кстати, этот самый баг стал чуть ли не центром повествования в одном из эпизодов сериала «Меня зовут Эрл».

Есть мнение, что шумиху вокруг Y2K развивали в основном откатчики (обеспечение госконтор Y2K Compliant софтом, должности типа Y2K Compliance Manager, конторы по тестированию на совместимость с Y2K…) — короче, под это дело было съедено немало средств, человеко-лет и машинного времени тоже.

Настоящей баг-легендой можно назвать операционную систему Windows версии 95-98, а также выкидыш этой серии Windows Millenium, занявшую шестое место в списке худших программных продуктов ушедшего тысячелетия. С выходом висты мелкомягкие вступили в борьбу за первое место в текущем. За преждевременный выпуск этих продуктов их создатель Билли был стопицот раз проклят и приговорён к пятнадцати годам публичного расстрела через повешение за борт на электрическом стуле, а также вошёл в историю и анекдоты мемом — «It was a beta-version!»

Классификация[править]

Баги в WinXP. Теперь и с музыкой.
И еще немного.

Баги классифицируются по степени их вредности:

  • Blocker — система или её часть не работает, невозможно использовать функционал. Пример — приложение крешит на старте.
  • Critical — баг, очень заметный для юзера и затрудняющий работу с системой, но не блокирующий её полностью. Пример — приложение даёт возможность купить товар, но зависает при просмотре списка подтверждённых заказов.
  • Major — система работает, но не так, как нужно. Пример — при покупке клиенту ВНЕЗАПНО начисляется скидка 3 %, которая вообще-то не планировалась.
  • Minor — с системой всё в порядке, но что-то режет глаз или незначительно мешает работать. Например, не работает скроллинг перетаскиванием ползунка, но страницу можно скроллить колёсиком мыши.
  • Trivial — баг, который не влияет на работу программы. Например, ошибка в тексте.

Соответственно строятся и приоритеты фикса. Сначала разрабы будут чинить блокеры и криты (если они есть), потом мажоры и только потом, если/когда будет время — миноры и тривиалы.

В некоторых трекерах используется другая система приоритетов — High, Normal, Low, Lowest. По сути то же самое.

Также баги классифицируются по частоте появления:

а также по тому, кто и где заметил симптомы. Например, если баг заметил Мегабосс Всех Заказчиков на уже запущенной системе, то баг будет исправлять все выходные весь IT-отдел, включая уборщицу.

Особо приятные баги — showstoppers, найденные в пятницу вечером. Они могут доставить несказанное удовольствие любому программисту, который любит уходить с работы в субботу утром.

Баги в больших количествах производятся индусами и китайцами, а также различными быдлокодерами. Продукты, содержащие передоз этих багов, называются багодромом.

Имеется специальное заклинание «Это не баг, это фича», которое позволяет избавиться от бага с наименьшими потерями, то есть ничего не делая. Однако этим колдовством владеют только самые опытные программисты.

Иные виды багов[править]

  • Плавающий баг — баг, который проявляется не всегда, а при каких-то неизвестных условиях. Например, как описанный ниже случай с Су-24: оказалось, что чтобы его увидеть, нужно особо точно зайти на цель. Есть несколько особых разновидностей плавающих багов:
    • Баг Гейзенберга — в честь одного из «отцов» квантовой механики. Суть в том, что баг исчезает, как только пытаешься его «отловить». Чаще всего это происходит когда нужно работать с многопоточностью в асинхронном режиме. Возникает состояние гонки, когда данные из разных потоков могут приходить в разное время и пошаговая отладка не поможет: пока ты поставил один поток на паузу, другой отработал и уже не мешается первому.
    • Баг Шрёдингера — полная противоположность: не проявляется до тех пор, пока о ней не узнаешь. Скорее миф: чаще речь идёт о багах, выглядящих так, но на самом деле они проявились не оттого, что их обнаружили, а оттого, какие действия предприняли после этого. Например, сказали пользователю «не суй лампочку в рот», а он сдуру возьмёт и засунет.
    • Баг с отложенным эффектом — развалившийся стек, потерянные указатели и просто испорченные данные, которые используются далеко от места, где они испортились. Воспроизвести просто, найти причину сильно сложнее. Например, если два потока пишут в одну общую переменную, а программист не удосужился поставить семафор (или поставил не там, где следовало)
      • В частности, могут получиться из-за полного заполнения долговременной памяти — то бишь, жесткого диска. Хотя места в наше время на дисках много, но допускать его полного (до упора, под ноль) заполнения нельзя (да и держать запас памяти полезно).
  • Баги с переполнением числовых значений — о них есть отдельная статья.
    • Не путать с переполнением стека/буфера. Эти баги одно время широко использовались хакерами для того, чтобы через безопасные с виду файлы распространять разного рода зловредов, а также, например, для самостоятельной модификации прошивки устройств, в которых она не предусматривалась — например для снятия региональных ограничений.
  • Перекрёстные баги — когда минус на минус даёт плюс. Бывает, что две ошибки в коде полностью компенсируют друг друга и единственное следствие — что становится непонятно, как этот код вообще работает (что тоже плохо и сулит баги в будущем). Но чаще один из багов — какая-нибудь мелочь, но если его исправить всплывает другой, который не проявлялся как раз из-за исправленного. Если программист был пьян, такие баги могут порождать длинные цепочки.
    • Бывает, что баг невозможно исправить (например, если он в чужой библиотеке, кода которой у тебя нет), или просто влом — тогда ставится костыль. Когда же изначальный баг исправляют, костыль сам становится багом. Хуже когда на этот костыль опирается что-то ещё.
  • Баги, внесённые программистом намеренно. Например, если программист обиделся и перед уходом решил сделать работодателю подлость. Сегодня, в век систем контроля версий, обзора кода и разработки через тестирование провернуть такой трюк тайно сильно сложнее (хотя там, где из жадности или косности продолжают работать по старинке, такое ещё может случаться), а до конца XX в. случалось регулярно. К примеру, в 1982 на АвтоВАЗе обиженный программист подправил код так, чтобы через некоторое время после его ухода в отпуск случилась рассинхронизация в работе конвейера, и как выяснилось — это был не первый случай. С другой стороны, заказчик, не имеющий доступа к исходным кодам и системе контроля версий, всё ещё уязвим к таким атакам, если это делается в сговоре или с прямой санкции руководства разработчика.

Постинг бага[править]

Баг заносится в специальную систему, называемую трекер (англ. tracker — отслеживатель), например Jira или Redmine. Описание бага делается по следующему шаблону:

  • Заголовок (англ. heading) — о чём в целом баг.
  • Описание (англ. description) — более подробно в чём суть бага.
  • Автор (англ. Reporter) — кто запостил баг. Проставляется автоматически по учётной записи в трекере.
  • Ответственный (англ. Assignee) — либо проект-менеджер заказчика, который будет потом раскидывать баги по разрабам, либо непосредственно разраб, который будет чинить баг (если он известен и разрешено кидать баг сразу на него). Назначается вручную.
  • Шаги для воспроизведения (англ. steps to reproduce, STR) — что надо сделать, чтобы воспроизвести баг. Прям по шагам с номерами.
  • Фактический результат (англ. actual result) — что происходит в итоге.
  • Ожидаемый результат (англ. expected result) — что должно происходить. Обычно берётся из техзадания (ТЗ), здравого смысла или согласования с заказчиком «должно быть так».
  • Окружение (англ. expected result) — тип браузера/девайса, на котором баг воспроизводится. Чаще всего это all devices, но бывают баги, которые воспроизводятся только в определённом браузере или на определённых девайсах/платформах.
  • Версия/ревизия клиента (англ. client version) — версия приложения, в которой найден баг.
  • Аттачи (англ. attachments) — скриншоты и видео, подтверждающие проблему. В некоторых случаях также нужны логи.

Пример:

Подробнее...

Заголовок: Ошибка 404 при переходе в корзину товаров

Описание: При переходе в корзину товаров пользователя появляется ошибка 404.

Шаги для воспроизведения: 1. Открыть сайт 2. В правой боковой панели нажать "Корзина"

Фактический результат: Появляется ошибка 404

Ожидаемый результат: Открывается экран с корзиной товаров

Окружение: Chrome 85

Версия клиента: 1.0.1234

Новые баги имеют статус New/Open/To Do в зависимости от трекера. Когда разраб фиксит баг, он переводит его в статус Fixed и задача тестера — проверить, что баг исправлен в следующей версии приложения. В зависимости от результата проверки тестер закрывает баг (Closed — проблема исправлена) или переоткрывает обратно на разработчика (Re-Open — проблема не исправлена), чтобы тот фиксил снова.

Тестирование[править]

Основная статья: Тестировщик
Краткий мануал

Для отлова багов в программах используют специально обученных охотников во все возможные дыры, называемых тестировщиками. Первой их задачей является сломать программу любыми средствами. У идеального тестировщика в вакууме на компьютере не работает ничего, потому что он всё сломал. У обычного тестера должна не работать только одна конкретная программа. Также является профитом, если тестер ломает мебель, бьёт стёкла и рвёт занавески. Пример.

Как известно, программисты очень сильно любят тестеров, поэтому тестер должен обладать разрядом по боксу для общения с особо неадекватными их представителями. А также тестер должен обладать рефлекторным умением посылать фаербол в ответ на заклинание «это фича».

Где встречается[править]

Внимание! Просьба добавлять сюда только внутримировые примеры, где программные баги или трудноуловимые ошибки аппаратуры играют заметную сюжетную роль. Для прочих багов в видеоиграх на проекте есть упомянутые выше статьи, тут им не место. В раздел реальной жизни стоит помещать наиболее знаковые и забавные примеры, так-то багов, приводивших к серьезным последствиям, было великое множество. Также просьба не помещать сюда просто примеры взбунтовавшихся или осознавших себя роботов, поскольку это другие тропы, хотя и безусловно родственные.

Литература[править]

  • С. Лем любит такие фокусы, правда в силу времени написания, они чаще имеют техническую или смешанную, а не чисто программную, природу:
    • «Рассказы о пилоте Пирксе»
      • «Патруль». Пиркс раскрывает загадку исчезновения нескольких, таких же как он, патрульных: при определённых условиях система наблюдения корабля начинает проецировать фантом, выглядящий как неопознанный корабль, вдобавок его мерцание слегка гипнотизирует пилота. Впавший в транс пилот в погоне за электронным призраком разгоняет ракету, пока не кончаются топливо и кислород.
      • «Терминус». Пограничный случай, поскольку причины не объясняются. Пиркс обнаруживает, что старый робот на прошедшем капитальный ремонт корабле каким-то образом запомнил и периодически воспроизводит переписку запертых в своих отсеках и перестукивающихся азбукой Морзе умирающих астронавтов. Это производит жуткое впечатление, словно в роботе обитают «призраки» погибших, не осознающие своей смерти. Окончательного ответа, так это или нет, является поведение робота просто артефактом сбоящей техники или «призраки» в его памяти осознают себя, рассказ не дает.
        • Когда Пиркс пытается войти в контакт с ними, ответ таки получает, а потом «призраки» начинают спрашивать, кто он. Но тут мы подходим к проблеме китайской комнаты
      • «Условный рефлекс». Из-за сочетания нескольких факторов на отдалённой лунной станции аппаратура иногда выдает такую картину, словно вышедший для обслуживания научной аппаратуры член команды сорвался в пропасть и теперь умирает, хрипя в микрофон. Дополнительной жути на наблюдателя нагоняет тот факт, что во время постройки станции такой случай действительно произошел и человек много часов умирал под обвалом именно в этой пропасти. Кинувшийся на поиски «погибающего коллеги» космонавт сам становился жертвой, а его вернувшийся напарник кидался следом за уже реальным пострадавшим, с тем же результатом. К счастью для напарника Пиркса, пилот оказался не склонен к мистике, зато склонен к трезвому логическому мышлению.
      • «Ананке». Робопилот в процессе своего программирования-обучения воспринял от «наставника» вынесенное в заглавие психическое расстройство (кратко говоря — крайнее упрямство, педантизм и склонность к запредельному перфекционизму). Это приводит к катастрофе, когда в тривиальной ситуации, при штатной посадке на планету, корабельный компьютер самостоятельно начинает усложнять задание. Заодно и пример сбывшегося прогноза: в некоторых из модных сейчас нейросетей похожий эффект действительно может возникнуть.
  • А. Азимов, рассказ «Как потерялся робот» из цикла «Я — робот». Первый из трех азимовских законов роботехники гласит: «Робот не может причинить вред человеку или своим бездействием допустить, чтобы человеку был причинён вред». Для работы на одной из космических станций в обстановке секретности (земное общество и так весьма настроено против роботов) была выпущена серия машин, в которой этот закон был урезан до первой части — «не может причинить вред», ведь работа в опасных условиях подразумевает, что человек вынужден иногда сознательно идти на риск или даже вред для себя, чего обычный робот допустить не может. Однако такое изменение закона порождает возможность фактически убить человека: теперь закон не мешает роботу намеренно создать опасную ситуацию, зная, что его способностей достаточно, чтобы спасти человека, значит, его действия напрямую не угрожают человеку, а затем просто не вмешиваться, ведь закон больше этого не требует. Пример намеренно заложенного эксплойта, приведшего к неожиданным последствиям.
  • С. Лукьяненко:
    • «Лабиринт отражений». Во второй книге серии упоминается, что дайверы могли видеть ошибки программ просто так, без исследования и поиска. Например, пробел в системе безопасности выглядел для них как дыра или незапертая дверь в стене. Правда в первой книге ничего подобного не описано, все суперспособности дайверов ограничиваются возможностью в произвольный момент времени выйти из виртуальной реальности и избавиться от эффектов, действующих на других её посетителей.
    • «Спектр»:
      • Человеческая версия пульта управления системой порталов между планетами позволяла выбрать не одно, а несколько мест назначения, при этом проходящий через портал размножался на все выбранные. Через сочетание «CTRL+левая кнопка мыши» — ага, как винда. Оперативно пофикшено. В тексте прямо описано, что способ управления зависит от путешественника: войдёт в ту же комнату геддар — вместо человеческой клавиатуры появятся геддарские рычаги. Так что это не у инопланетян есть клавиша Ctrl, это у людей есть клавиша Ctrl. Вдобавок, будь там натуральная винда — в ней возможность выделения нескольких пунктов по умолчанию выключена, а кто и зачем стал бы специально её включать? Скорее можно предположить, что интерфейс подстраивается под ожидания пользователя: Ирина ожидала, что в винде можно выделить несколько пунктов разом — пульт, косплеющий винду, послушно выделил.
      • Ещё один схожий баг — «размножение» Семецкого. Здесь даже не потребовалось выделения нескольких пунктов списка, достаточно было пройти Врата пьяным в дымину.
  • Павел Шумил, «Слово о драконе» — пример не программного бага: наиболее значимая техника Повелителей снабжена блоком самоуничтожения, срабатывающим после достаточно длительного бездействия, чтобы опасная аппаратура не попала в руки недостаточно развитой цивилизации. Вот только, к счастью для главных героев, в конструкции камер нуль-Т была допущена ошибка: контакты блока и прочей начинки состояли из различных металлов и создавали разность потенциалов, которая в конце концов привела с разрушению контактов[5]. В результате блок самоуничтожения не сработал и главные герои успешно получили доступ к аппаратуре.
  • О. Дивов, рассказ «На три буквы». Из-за предмета статьи, вместо того, чтобы нормально транслировать рекламный лозунг на прекрасно заметный с Земли на фоне вечернего неба экран спутника, программа принялась резать его кусками и показывать в таком виде. Зато крупно. Да еще не с начала, а с десятой буквы, а потом заново с начала. Лозунг был: «Застрахуй машину в “Бастионе”» и резался, в соответствии с названием рассказа, кусками по три.
  • «Бета-тестеры» — не только для этого, но в том числе.
  • Идеальный тестер — тестировщики нужны именно для этого.

Видеоигры[править]

  • Deus Ex: Human Revolution — если ближе к концу согласиться поставить «обновление программного обеспечения для имплантов» в официальной клинике «Протез», то очень быстро протагонист словит неслабые глюки (и это еще мелочи, большая часть обладателей имплантов впадёт в безумие): в обновление намеренно была внесена уязвимость (т.е. недостаточная «защита от дурака» или злоумышленника, которым в этот раз был сам автор программы).
  • Star Control 2 — агрессивность мирных зондов Слайлэндро была багом.

Реальная жизнь[править]

  • Y2K. Вопреки апокалиптическим настроениям журналистов, баг не слишком серьёзный (подумаешь, за 1999 годом вместо 2000 наступит 1900. Или 19100), зато каков масштаб — он затронул практически весь цивилизованный мир! И заодно сильно повлиял на методологии разработки ПО: например, наглядно показал, что принцип «работает — не трогай!» применим далеко не всегда.
    • Хотя негативные последствия всё же были. В одной клинике произошёл сбой, и перепутались результаты анализов на риск синдрома Дауна у плода. В результате были абортированы два здоровых эмбриона, а в других семьях родились нежеланные больные дети. https://habr.com/ru/company/alfa/blog/517096.
  • Один из наиболее известных случаев программного бага с трагическими последствиями — ошибка в программе аппарата для лучевой терапии рака Therac-25. Аппарат выдавал слишком большую дозу облучения, в итоге — как минимум шесть пострадавших и двое погибших. Самое печальное, что пациенты обычно обращали внимание на необычные и болезненные ощущения, но врачи не сразу им поверили.
  • В 1962 ошибка в программе привела к отклонению от курса и взрыву космической ракеты Mariner-1.
    • Сюда же авария при первом запуске ракеты Ариан-5 в 1996. Полётное ПО разрабатывалось на основе ПО для ракеты предыдущего поколения, Ариан-4, поэтому часть кода была перенесена оттуда. В том числе один маааленький модуль на три строчки который вообще не был нужен на новой ракете. И так как новая ракета была более резвой, чем старая, случившиеся в полёте переполнение переменной этого модуля вызвало зависание обоих бортовых ЭВМ, основного и резервного, что запустило аварийный механизм самоуничтожения ракеты. Считается самым дорогим багом в истории, около 500 миллионов на ракету и спутники на ней. К тому же, был нанесен ущерб репутации самой серии ракет, следующий запуск спутников производился с Байконура на «Союз-Фрегате», хотя новый «Ариан» уже был готов.
    • Тоже не самый дешёвый баг — спутник w:Mars Climate Orbiter разбился из-за того, что в программе часть величин была задана в метрической системе мер, а часть в имперской. 200 млн долларов в трубу.
  • Скорее анекдотический и комичный случай — при испытаниях Су-24 регулярно возникала ошибка в ПО самолета, приводившая к его перезагрузке, но только если в кресле пилота был лётчик-испытатель Ильюшин. Как выяснилось после долгих поисков, этот лётчик стабильно заходил на цель с такой точностью, что отклонение становилось меньше минимального числа, которым мог оперировать компьютер самолёта. В результате в системе коррекции прицела возникала ошибка деления на ноль.
  • Известный случай времен сирийской войны 1960-х. Американские лётчики вынуждены были летать на низких высотах, чтобы их не замечали радары, но при полётах над Мёртвым морем у многих из них внезапно перезагружалась вся бортовая электроника самолёта. Причину обнаружили только тогда, когда вспомнили, что уровень воды в Мёртвом море ниже официального «уровня моря», который в высотомере был установлен как ноль. В итоге система делила на ноль с закономерными последствиями.
  • Гибель нескольких новейших «боингов» в результате того что начальство «Боинга» решило очень круто сэкономить, уволив дорогих специалистов и наняв индусов, которые согласились написать новые программы для «Боинга»… бесплатно! (надеясь на дальнейшее сотрудничество с «Боингом» в будущем). https://habr.com/ru/post/458224/

Примечания[править]

  1. Хотя, если подумать, сама эта запись подразумевает, что были и более ранние случаи, в которых просто не было «реально обнаруженного жучка». То есть слово стало означать ошибку/сбой ещё до того. Кстати, по одной из легенд, первое применение слова bug по отношению к технике приписывают еще Томасу Эдисону. Во время работы над фонографом он якобы долго не мог понять, почему же собранный прототип отказывается работать. Перебрав в уме все возможные варианты и так и не найдя решения, он предположил, что во время сборки между деталями устройства мог попасть жук. И хотя на самом деле никаких насекомых в фонографе не оказалось, в будущем он продолжил использовать слово bug для обозначения досадных неисправностей.
  2. Например, если в программе на некоторых языках напечатать «=» вместо «==», то вместо сравнения двух значений получится запись значения справа от выражениия в переменную слева. Если такое действие в данном случае возможно, сама программа ни о какой ошибке не сообщит — откуда ей знать, хотел программист поменять значения или только сравнить? А потом у кого-то годовая премия станет равной нулю.
  3. В еще более некоторых языках (точно в JavaScript, но, возможно, он не уникален) из-за крайне нетривиальной типизации есть нежно любимая разработчиками разница между сравнением по значению и по типу, в которой последствия ошибки еще более неочевидны.
  4. Шутки шутками, а порой UB может приводить к совершенно непредвиденным ситуациям, которые оказываются вполне логичными после изучения работы конкретного компилятора.
  5. Подобное бывает в реальности. Например, если срастить кабель чувствительной аппаратуры куском кабеля из другого металла, будут помехи. Постарайтесь воздержаться от этого, ибо обнаружившие баг ремонтники непременно пожелают нанести автору тяжкие телесные повреждения.

Ссылки[править]

См. также[править]

App.png Весьма полезная вещь, позволяет машинам работать с помощью коммандычей
МетаПрограммаDRM (SecuROMStarForceАналоговая дыра) • БагБот (Автоответчик) • Варез (Repack) • ГлюкГуйДонатКопирайт (By design) • ЛогНюкРут (Не работай под рутом) • Спортивное программированиеМегапиксельКомпьютерВерсия 2.0КодОбфускацияСкриншотДатамайнПлагинТекстовый файлБольшие данныеАльфа и бета-тестыТаймстампКэшШаблоныHello WorldНейросетиФайлИнсталляцияВидео
ФичиБагрепорт12309BSODCookiesEmbrace, extend and extinguishFL StudioSheep.exeWinlogon.exeБубенЗащита от дуракаКостыльМашинный переводПасхальные яйцаСвистелки и перделкиСм. рис. 1Съешь ещё этих мягких французских булокTermuxGNU MetroИндусский кодНескучные обои • Сжатие (За сжатие ДжипегаШакалШкала) • Работает — не трогайРандомайзерPDF (Распознавание PDF) • Дело Google в ФАСЧат-ботXMLМакросКритическая ошибкаФреймворкСинонимайзерSourceТрёхмерное отслеживание
ВредоносноеБотнетБрутфорсВинлокЗвонилкаКитайские пингвиныПиксель смертиТроянЧервь МоррисаBonziBuddyMediaGetBrowser hijackingTinderМиссис МажорУтечка буфера обменаWin 10 TweakerОпараш Mozilla FirefoxЯндекс.МузыкаКрэкерБезопасность через умолчание
КомпанииApple / Apple (AppleScript) • GoogleMicrosoftSAPЯндекс
Движения8-bitOpen source (КрасноглазикиЛинуксоиды) • Вирусная сценаДаунгрейдДемосценаМоддингMMD
Офис3DS MAXGIMPGNU EmacsMovie MakerMS Paint • OpenOffice • PowerPointviMicrosoft WordExcelБлокнотФотошопАнтивирус КасперскогоAvast!TikZShareXAlternativeToСкрепышMicrosoft OfficeТекстовый редакторWeChatZoomДиспетчер задачMicrosoft CortanaWinampBallonTranslatorKerish DoctorОбщая ошибкаFirefox: Как один баг сломал весь YouTubeМеждулициеMeld StudioLadybirdCheat Engine
ОСAndroidBSDDOSMenuetOSReactOSWindows (Phone 7Phone 878Vista) / МаздайЛинуксРусская ОСФантом ОС
БраузерыInternet ExplorerОпера / Opera • Тормозилла (ОгнелисLolifoxMozilla FirefoxFirefoxFirefox Klar) • Хром (шпионаж) • SafariЯндекс.БраузерУведомления в браузереVivaldiTor-браузер
ИнтернетAdobe Systems (Flash) • I2PLow Orbit Ion CannonTorTunatic • Чат−клиенты (MirandaQIPSkypeЖабберDiscordVIPole) • HTTPSПрокси-сервер (Proxifier) • Торрент (Magnet-ссылкаΜTorrent) • JavaScriptCSSHTMLБаннермейкерИзменение TTL сетевых пакетовКапчаICQFiddlerViberZonaSteamSillyTavernWickr Me
РазработкаBrainFuckCC++C#JavaHaskellАссемблерChaos ConstructionsBATMySQLGitHubAutoHotKey (AutoHotInterception) • Sublime TextAPK (APKPureзапрет) • BASICPerlPythonPHPФоркUnity3DSAISIPСАПРФлагUTAUФласк макросАуработRaidCallAdobe MingОфициальный™ список кошерных программDevOps
ЛюдиВеб-мастерLovinGODБалмерГейтсГенерал ФейлорДжобсМитникПоттерингде РаадтСпольскиСтоллманТорвальдсШахиджанянAche666Марк ЦукербергЕвгений ПоповДенис КумпонМассовая компьютерная безграмотность
КостылиCygwin • PunkBusterT9WineWishmasterАнтивирусыХакинтошСборки WindowsDenuvoЧистая установкаКалькулятор Consul WarMicrosoft StoreUBlock OriginLightshotAdBlockSearchApp.exeCPU-ZГуглPhotoshop
Команды^H^WAlt+F4Ctrl+Alt+Delman/me/quitrm -rf
Чудеса науки
ПонятияБудущее ради будущегоЛженаукаНаука — это крутоОсторожная наукаРади науки!ТехнорелигияФантастическое допущениеЭффект фуллерена
ТехнологииGPSАнабиозВсемирная сеть (Даркнет) • Деревянный звездолётГаджетГидравликаЕвгеникаЗащита от дуракаКабель вместо батареекКлонированиеКосмические шахтёрыКосмический лифтЛюминесценцияМашина Судного дняМутагенНаномашиныНеработающая технологияРаспознавание лицСамоуничтожениеСиловая броняСистема жизнеобеспеченияСмартфонСтрельба элементарными частицамиСыворотка правдыТелепатический интерфейсТерраформингТермоядерный реакторТрансформерЦиклерЧудеса от науки
БананотехнологииАгентство паранормальных исследованийЕ=const vs. Неиссякаемый источник энергииАнтигравитация vs Искусственная гравитацияБоевой многоножникБластерВоздушный авианосецВымышленные вещества (Хлористый пандемонийХренполучий) • ГиперсвязьГлаза-лампочкиДжетпакЗвёздный истребительЗелёные камушкиИнтернет из летающей тарелкиИспользовать мозг на 100%Квантовая магияКосмическая мегапушкаКровь роботов и Язык роботов • Летающая техника и/или транспорт (автомобильдоскамотоциклподводная лодкатарелкатанк) • Луч смерти (Дезинтегратор) • Магическая лженаукаМатемагияМашина времениМозг в банкеМономолекулярная нитьНе электричествоНейтронная мегалоплазмаНеонкаНепонятная штуковинаНИИ магииОрнитоптер/МахолётОткрытие, которое перевернёт весь мирОрганический компьютерПатентованное средствоСакральная машина • Сверхнаука (древняяинопланетная (нечеловеческая технология) • нацистская vs советская) • Силовое поле (треснувшее) • Стазис-полеСупер-РАСТИШКАТайные исследованияТвёрдый светТехногенное месивоТехнология получения суперспособностейТехномагияТирьямпампация (Гипердрайв) • ТрансформерУстаревшие научные теорииФлеботинум (Импортный инопланетный флеботинумМодный флеботинумПрикладной флеботинумНеправильно применимый флеботинумПолезный в хозяйстве флеботинум) • Шапочка из фольгиШизотехЯкорь реальности
Глазами гуманитариевВысокотехнологичные шестиугольникиГолливудская кислотаДатировка по электронике vs Будущее не оправдало ожиданийМашина ГолдбергаЖелезный кнопкодавЗелёный свет радиацииКопирование — это простоКрасная кнопкаМобильник ловит где угодноМонооксид дигидрогенаПостапокалиптическая сверхнаукаРадиация — это магия!Разноцветный космосСтандартные неразрешённые загадкиУдар молнии творит чудесаУникальный прототипФутур-ретроХорошее электричество, плохое электричествоШумный космос
Компьютерная магия: Взрывающиеся мониторыВыстрелить в мониторГолливудское хакерство (Взлом через ПейнтВзрыв АЭС через Wi-Fi) • Зелёные буквыЗрительский интерфейсКнопка увеличенияКомпьютерные вирусыМедленный перевод денегМагическая база данных • …
Люди наукиАрхеолог-авантюристГений — это волшебная наукаГерр ДокторМагистр всяческих наукНевезучий изобретательНикола ТеслаНеэтичный учёныйПрогрессор vs СтагнаторПрофессор Выбегалло (Дилетант с мировым именем) • Сам себе подопытныйУчёный (Небеснокаменный учёныйПрофессор ФансервисСумасшедший учёныйУчёный и офицерУчёный и политикУчёный и священникУчёный выглядит как ЭйнштейнУчёный-схоласт) • Человек эпохи Возрождения Нетайная организация
Стереотипные локацииАкадемия наукБиблиотекаЛаборатория
ПроблемыБагАномалияБоги забрали огоньБольшая ошибкаНаука не работаетНаука — это плохоЗлокачественная автономная технология (Бунт машинСерая слизь) • Лишние деталиНе бывает!Неправильное использование науки (Неправильное использование патентов) • Предварительные испытания не нужныТехнологическая сингулярностьТрансгуманизм — это плохоУчёный изнасиловал журналистаУчёный не сумасшедшийФлеботический бунтарь
СуществаГолосовой помощникДемон Лапласа (Омега) • Демон МаксвеллаКот ШрёдингераМышь ЭйнштейнаМозг БольцманаФилософский зомби
Псевдонаучные теории
(то, что даже на «банан» не тянет)
25-й кадрПрошивка крутизны/Память предковДети индигоЛенин — грибПередача душиПротивоземля
Видеоигровые термины
Игры и
приложения
DLCHotseatShovelwareАддон (Аддон-переворот) • ДемкаДемо-версияИгра поддержкиИнди-игрыЛицензированный трешМинииграМод (Антимоддерская фича)/Пиратские игры/Фанатские игрыНовая игра — новые правилаСистема рейтинговШкала свободы действийЭпизодная структура в шутерах
БалансАсимметричный конфликтКлассификация фракций (Быстрый, сильный и хитрый) • Золотой снитчИмба (Временная имбаЗапоздалая имбаНамеренная имба (Гейм-эндерТерминаторизатор) • Ненужная фича (Имба у врага — пустышка у игрокаРезиновый нож) vs Добровольно-принудительное умение (Запоздалое принуждениеОбыденная имбаТрудно, но не невозможно) • супероружие в RTS) • Камень-ножницы-бумагаНубская труба vs. Нубская имба (Убийца ИИ) • Сверхбыстрое моральное устареваниеСвятой РандомийСиндром оркаСиндром протоссаСила Мэджикарпа vs Стартовый ускоритель • Эти гадкие… (АтакаАчивкаБоссКартаМеханикаМоб (hitscan-пулемётчик) • Уровень)
ГеймплейGame over (Save scumming vs перманентная смертьМножество способов умеретьНестандартный геймоверПлюнуть в могилу) • Limit BreakRage-barАктивная паузаАльтернативный огоньБуллет-таймВзаимоисключающие технологииВнезапная смена геймплеяГеймплей вразрез с сюжетом (Ветеран-дилетантдали только пистолети пусть весь мир подождёт (Ручная перемотка времени) • катсценная некомпетентность vs сила катсцен на максимумкатсценное умение) • Закон подозрительной щедрости в видеоиграхЗаявленное проклятиеЗлой рандомИгровые очкиДостижения (Глумливые ачивкиНеофициальная ачивкаЭта гадкая ачивка) • ИнвентарьКак научиться плаватьКрасная сельдь (Склад красных сельдей) • Критический ударЛимит содержания vs Очки командования/Очки лидерстваЛожный выбор (Гадские рельсы) • Лоскутная картаМожно грабить караваныМультикиллНажми Старт, чтобы умереть vs Нажми X, чтобы не погибнуть vs Нажми X, чтобы умереть vs Нажми Х, чтобы победитьОверкиллОчевидный выбор vs Кажущийся очевидным выборПостулат лорда Бритиша • Принудительный геймплей (Стелс vs Экшен, Миссия без базы) • Синдром Буриданова ослаСломанный интерфейсСлучайные столкновенияПрокачка удачиПроклятие — всегда проклятиеПоражение неприемлемоРандомСтелсЭволюция главного менюЭта гадкая механикаОчки работы
УсловностиАрмия ИзбранныхВидеоигровая биология (волшебные аптечкизатыкать насмертьисцелися самЛечение через питаниесиндром Росомахи) • Волшебное превращение ресурсовВсегда знает свой результатЛегенда-новоделМилорд фактотумНикому не нужные сокровищаОбоснуй фасттревелаОсвещённые подземельяОтличная связьПсевдоодноместностьФарм главгадов
СложностьНавязанный хардкорНе играй на лёгкомПианиноПик сложности (Скальный наездник (Этот гадкий hitscan-пулемётчик) • Эта гадкая атакаЭта гадкая ачивкаЭта гадкая картаЭта гадкая механикаЭтот гадкий боссЭтот гадкий сайдквестЭтот гадкий уровень) • Подсказки для слабаковФальшивая сложность vs Хардкор
РеиграбельностьВзаимоисключающий контентГенератор квестовНовая игра+Обоснуй перепрохожденияПостгеймоверная прокачка
Баги, фичи и
читы
Save scummingАнтивредительская фичаАнтизадротская фичаАнтизастревательная фичаАнтизастревательное маклаудствоАнтипиратская фичаАнтичитерская фича vs Чит-код (Код Konamiчит за деньги) • Баги - это смешно vs Баги – это страшноБагофича (Совершенно законный финт ушами vs эксплойтСпидран) • Игра вне игрыИграть в экселеКривой монтажЛегальный читНепроходимая забагованность (патч скачал? Проходи сначала!) • Несуществующий игровой секретОдноразовый инструментПасхальное яйцоРусефекацияФичекат (Отключённая фича)
Тактика и стратегияДесболлЗаказное строительство/Рабочая силаЗатыкать насмерть vs Тактика тотального ваншотаЗашиваниеКайтМакроконтроль и микроконтрольРазбафРашСпамСтанлокпервым бей медика/вторым бей магикаТактическая смертьТанк-приманкаХарассить противника
Игровая механикаВнутриигровой конструкторКвест (геймплей)(Генератор квестовКлассовый квестКвестовая причинаКвестовое везениеСайдквест (гадкий) • Секретный квест) • КрафтРолевая система (МанаОпытПеркСкиллСтандартные атрибуты персонажа) • Боёвка/Система повреждений (Маленькие синие пулькиОдин хитбар на всёОдин хитпойнт vs Очки жизниОчки действияПериодический уронРезистСтандартные эффекты состояния)
РазноеAcknowledgement (Никто не смеет мне приказывать!нужно больше золотанужно построить зиккуратхватит в меня тыкать!) • Ад в начале игрыАлхимия — это простоА оружие отнимем у противника vs Не будем брать оружие противникаБезнадёжный бойБунт населенияБунт соратниковВзаимоисключающие напарникиВоины — по прямой, маги — по параболе vs Воины — по прямой, маги — в задницеГимпДаунгрейд (Никакой не апгрейд vs Никакой не даунгрейд) • Жестокость в видеоиграх/Видеоигры поощряют добротуДымовых гранат не существуетЗахват флагаЗнать, где упадёшьИгра по разным правиламКаскадный резонансКнига заклинаний • Концовки (быстраядосрочнаязолотаяканоническаямодульнаяоткровенно халтурнаяплохая-красочнаяплохая-непонятнаяплохая-трудная) • Первый напарник — воинКризис поздней игрыКрутой с 1000 хитовКупи долбаный гайд! (Нубский мост) • МетагеймингМеталлолом и макулатураМыльное кинцоНа голову выше мираНам не помешает лишний стволНапасть со спиныНезаконные предметыНеобходимый напарникНе смей играть так!Нестандартная озвучка монстраОбесценивающиеся ресурсыОбъекты коллекционирования из видеоигрОдежда в качестве наградыОн просто слишком крут (Не действует на боссов) • Они повсюдуОфигенно находчивые разработчикиОфигенно предусмотрительные разработчикиПогибнуть в мелких взрывахПоощрение за стелсПоследний пришелецПрямая линия с врагомСделает напарник, а не яСмехотворно высокая ценаСмехотворно низкая наградаСон — лучшее лекарствоСохранениеСпециализированный контроллерСпособности фракцииСтандартные квестовые головоломки (Замок по Лойду) • Стелс бьёт экшнСтепени двойкиУнылое ожиданиеФарм в стратегияхФриплейЧто за фигня, игрок?Это плохо, понятно? Городской портал
Видеоигры