Умение разбираться в чужом коде

Материал из Неолурк, народный Lurkmore
Перейти к навигации Перейти к поиску
Через месяц, через год
Станет новым свой же код.
Не поймёшь, не разберёшь,
Да и нафиг всё пошлёшь.
— Народная мудрость
Умение разбираться в чужом коде реквестед[1]

«Умение разбираться в чужом коде» — строка-детектор, которая содержится чуть более, чем во всех вакансиях на должность программиста и смежные должности. Чаще всего акцент на этой фразе делается для вакансий разработчика на C++ и PHP, где «чужой» не только код.

Значение фразы[править]

  • Вроде как компания ищет высококлассного специалиста
  • Этот специалист должен быть настолько хорошим, что мог бы даже разбираться в чужом коде

На самом деле никакого такого умения не существует. Любой человек, способный писать, может и читать. Другое дело, что можно писать так, что потом сам хрен прочитаешь. Усугубляется это тем, что в сравнении с натуральными языками языки программирования, на человеческий взгляд, перегружены «пунктуацией», которая в них крайне важна и не терпит ошибок, а небольшие «слова» могут иметь очень большую (и неочевидную) смысловую нагрузку.

Потому и существуют гайдлайны, они же правила оформления. Например, не лениться использовать «говорящие» названия переменных и функций, даже если они длинноваты, оставлять комментарии в ключевых местах (то есть почти везде), не использовать goto-подобные операторы и так далее. И если подобных единых правил придерживаешься, то код хоть немного, но можно читать. Однако, код, написанный в спешке, почему-то получается нечитабельным у большинства разработчиков.

Настоящее значение фразы[править]

  • Нужен идиот, который согласен разгребать это дерьмо.
  • Руководитель свято верит, что причина получающегося дерьма в нерадивых программистах, а не в нём.
  • Разгрести это дерьмо у тебя не получится при любом желании, так как от тебя будут требовать писать всё больше и больше кода, который непонятно как придётся прикручивать к уже существующему, на вдумчивое разгребание времени не останется совсем.
  • В разработке архитектуры ПО используется метод «снизу вверх», требования меняются постоянно в зависимости от настроения левой пятки руководителя.
  • С 2011 года, среди Java-разработчиков, фраза приобрела новый оттенок: программисту подсовывают («посмотреть», доделать, переделать, заставить работать…), под видом собственной разработки, довольно качественный код, декомпилированный из какого-нибудь коммерческого продукта. Ну и...

Что мы узнаём об организации по такой вакансии[править]

  • Большая текучка кадров.
  • Некому толком поставить процесс разработки в верную позу. (При грамотной организации процесса разработки ПО, код получается таким, что разобраться в нём не составит труда для любого программиста.)
  • Темпы разработки постоянно подгоняются начальством, качество кода ужасно, переписывать приходится больше чем писать.
  • Качество ПО, производимого этой конторой — дерьмо.
  • Вам будут перманентно полоскать мозг.

Что мы узнаём о работнике[править]

Если фраза встречается в резюме, то означает симметричное:

  • Я готов копаться в любом дерьме
  • Я буду писать такой код, разобраться в котором можно, только обладая данным умением
  • Я умею заставить работать то, что накодили разработчики

Когда сабж оправдан[править]

Встречаются случаи, когда такое требование размещают в вакансиях оправданно. Это могут сделать после опыта работы с ковбоями-идеалистами. Когда такие люди сталкиваются с любой программой, они сразу же начинают истерить и пытаться переписать всё с нуля по своим лекалам. Тем не менее, «умение разбираться в чужом коде» это OCHE плохая формулировка. Годная альтернатива, это «терпимое отношение к чуждому коду». И всё равно строка скорее всего лишняя, так как должна подразумеваться в каждой вакансии программиста по умолчанию, что-то вроде столь же неимоверно популярного в вакансиях «умения работать в команде», которое на деле означает лишь «не быть мудаком» или «быть податливым мудаком».

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

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

А на самом деле[править]

А на самом деле это базовый навык без которого нельзя работать программистом. Даже если чужой код был написан твоим коллегой буквально вчера и вы вместе работаете над одним проектом. Кстати даже если с этим коллегой тесно общаетесь то вам все равно придётся разбираться в его коде без него хотя бы потому, что чисто физически тяжело запомнить все правки и то, зачем они были сделаны, особенно если проект большой. Вообще умение разбираться в чужих наработках свойственно всем профессиям со времён индустриализации общества: новый разработчик твоего кредитного лансера выкурил много старых чертежей перед тем как сделать в них свои правки.

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

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

  1. На самом деле, код из книжки Александреску и из либы Loki и при вдумчивом чтении всё совершенно понятно.
    — Я делаю особую, шаблонную магию
    — Не-не-не, Андрей Александреску, не-не-не

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

Movax1010h.png Глубокий смысл скрыт в этих неестественных языках
Языки программированияПромышленные: BATC#CC++JavaJavaScript (AJAX) • PascalPerlPHPPythonRubyABAPАссемблерВасикFortran (Профессор)
Эзотерические: BrainFuckHQ9++ErlangForthHaskellLISP (My other car) • PrologTclΤΕΧOracleMySQLGolangВ++Scala
ПрофессииБыдлокодерПрограммистТестировщикХакерХеллоуворлдщикIT-звёздыПрограммист (существо)
Методы и стилиReverse EngineeringАнти-паттернВыстрелить себе в ногуГрязный хакКод (индусский) • КостыльМетод научного тыкаПомолясьСвистелки и перделкиОчередьСпортивное программированиеОбфускацияБета-тестАльфа-тестШаблоныRegReplaceФреймворкБыдлокодIndex.phpОхота за жукамиКуМирКлеточный автомат
Средства разработкиSublime TextПодсветка синтаксиса кодаUnstable DiffusionAPIPythonTutorCodeWarsDataCampUnity3DКнижный PythonMallocСвязный списокSOLIDООПУказательNULLWeLang++
ЛюдиИлья КанторЮрий КлючевскийЭдуард ЛаасЭдвард СноуденСеймур Пейперт
Прочее++i + ++iDeadline%s640 килобайтCMSDummy modeЕГГОГFoobarGod is real, unless explicitly declared as integerGOTOIfconfigKISSRegExpSICPsql.ruXyzzyДискетаИнжалид дежицеКОИ-8ЛогМанРекурсияСУБДТест ТьюрингаУмение разбираться в чужом кодеФаза ЛуныФатальный недостатокПроблема 2000ТаймстампКэшЗапись в файл без кэша (Perl)Танцы с бубномКодач