image

Привет, Хабр! Меня зовут Леонид Титов, я бэкенд разработчик в #CloudMTS. Так уж сложилось, что я не только пишу код, но и иногда собеседую кандидатов. Мне нравится процесс, и, думаю, у меня это получается.

Начал я этим заниматься ещё на предыдущем месте работы, где мы с тимлидом собирали новую команду. С тех пор прошло уже N лет, практика продолжилась, и после очередного собеседования я решил упорядочить свои знания. Кто-то считает, что от собеседований вообще толку нет, а кто-то наоборот (не будем показывать пальцем) проводит их в 3-5 раундов. Я уверен, что собеседования нужны, но важно четко понимать, зачем именно.

На всякий случай уточню: в статье речь пойдет не столько про конкретные вопросы (хотя они тоже будут), сколько про выработанную мной методику и принципы, которыми я руководствуюсь, задавая те или иные вопросы.

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

Зачем вообще нужно техническое собеседование


image

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

Здесь стоит уточнить, какие ошибки собеседующий разработчик может с большой долей вероятности совершить.

  • Спрашивать про различные хаки, ноу-хау и хитрости

По моему опыту, конца и края этим «приемам» нет, все их знать невозможно, и поэтому использовать их как основные вопросы и «валить» ими кандидата — в корне неверно. Сам много раз видел, как это происходит. Обычно действующего разработчика просят подготовиться к собеседованию, которое будет через пару дней. Он собирает подборку «заковыристых» вопросов, которыми потом «валит» кандидата. Можно завалить кандидата и думать «Какой же я умный!», но при этом потерять ценного сотрудника.

  • Проверять специфичные знания

Есть вещи, вполне очевидные для конкретного разработчика в силу специфики его опыта или прикладной области. Далеко не всегда кандидат обязан их знать, и «валить» его проверкой таких знаний не имеет смысла. Знает — отлично. Не знает — это вообще ни о чем не говорит.

Основная задача — проверить базовую профпригодность. Не более и не менее.

Поясню, что я имею в виду. Допустим, мы собеседуем кандидата в разработчики на языке Х и видим, что он его отлично знает. У меня есть огромнейший бэкграунд работы с конечными автоматами (машинами состояний) — знаю о них больше, чем написано в университетском курсе. Я могу спросить кандидата: стоит ли выражать состояния целым числом, числом с плавающей точкой или строкой, какие плюсы и минусы есть? Мы сломали много копий на этом, и для меня ответ очевиден.

Нужно ли спрашивать об этом кандидата? Нет. Потому что это никакого отношения к профпригодности не имеет. Даже если нам с этим работать. Зато есть шанс, что кандидат на предыдущей работе был в команде, где это было «в эфире», слов нахватался, на вопрос ответит, хотя на самом деле как специалист слабенький. Welcome false positive.

  • Искать человека-энциклопедию

Подумайте, стоит ли на техническом собеседовании просить описать алгоритм поиска кратчайшего пути Дейкстры или спрашивать, как посчитать все биты равные 1 в очень длинном векторе. Каюсь, первый вопрос сам недавно задавал, но только по одной причине — кандидат много рассказывал, как он круто работал с графами, и должен был знать ответ. Однако помнить все эти алгоритмы не может ни один программист физически. Их настолько много, что завалить можно любого. Мы же ищем профпригодного кандидата, а не ходячую Википедию. Собеседование — это не тест IQ. Уровень интеллекта можно измерить и другими способами, например, с помощью готовых методик. Но это уже совсем другая история.

Приведу еще один вариант «плохого» вопроса. Например, мы собеседуем разработчика на Go и просим его рассказать, как сделать семафор с помощью канала. Почему этот вопрос плохой?

  • Во-первых, использование семафоров нетипично для разработки на Go, не идиоматично. Семафоров не было в стандартной библиотеке, они не используются в идиоматичной кодовой базе Go. Они, как правило, не нужны в прикладной работе.
  • Во-вторых, сделать семафор с помощью канала довольно просто, но это хак в чистом виде. Ведь мы эмулируем переменную состояний с помощью очереди, а это явно не классический семафор.
  • В-третьих, если так случилось, что кандидат где-то в интернете прочитал про этот хак, он легко ответит. Но это ничего не скажет о его профпригодности. Welcome false positive again. И наоборот — даже вполне профпригодный кандидат затруднится с ответом, если хака не знает. То же самое с вопросом, как использовать канал вместо мьютекса в Go.

Что такое «профпригодность»


Как понять, кто вам нужен? Заранее составьте список того, что точно должен знать кандидат как свои пять пальцев. И если он этих вещей не знает — вы его брать точно не будете.
Например, если мы берем разработчика на Go и его знания каналов или слайсов находятся на уровне «прочитал два раза, один раз попробовал», вряд ли он нам подойдет. Наверное, такие вещи он должен знать так, чтобы с ходу ответить на любой заковыристый вопрос, даже если его разбудить среди ночи.

А что делать, если мы работаем с брокером сообщений Х, а кандидат про него ничего не знает? Повод ли это его не брать или даже просто поставить минус? Уверен, что нет.

Как я уже говорил выше про такие вопросы:
Если знает — это плюс. Если не знает — это вообще ни о чем не говорит.

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

Защита от читерства и подготовки по списку


Окей. А если потенциальный соискатель прочитает эту статью, вопросы, подготовится и обманет собеседование. Возможно ли такое?

Опасаться не стоит. Есть железобетонная методика выявления того, насколько человек глубоко знает предмет. Называется она Asymmetric Information Management technique или просто AIM technique — техника ассиметричного управления информацией.

Если коротко, принцип достаточно простой: когда люди рассказывают о том, что действительно было, и/или разбираются в предмете, им нравится погружаться в детали. И наоборот — избегают погружения, когда знакомы с темой поверхностно или рассказывают небылицы. Техника с успехом применяется правоохранительными органами, и некоторые говорят, что работает она лучше полиграфа.

Применяет ее и Илон Маск. Его знаменитый «главный вопрос» на собеседованиях звучит так:

“Tell me about some of the most difficult problems you worked on and how you solved them.”


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

Однажды мы собеседовали кандидата на роль разработчика Go и позволили одному из коллег попробовать себя в роли интервьюера, я же просто слушал. Он задавал достаточно тривиальные вопросы «по списку» — например, про слайсы в Go — а кандидат уверенно отвечал. На фоне было слышно, как он гуглит. Минут через 7 я решил вмешаться и на тривиальных вещах про слайсы просто стал копать в детали. На втором вопросе кандидат просто повесил трубку. Мы даже сначала подумали, что это обрыв связи, так все неожиданно произошло. Но нет. Он видимо, что-то понял :)

Так что копайте вглубь, в детали, и обман не пройдет.

Первый раз «по ту сторону»


Я очень долго никуда не собеседовался. Хотя «долго» — понятие относительное. 15+ лет, это долго? Естественно, пропадает навык. Вообще это парадокс — только ты выработал навык находить работу, нашел ее, и он становится больше не нужен. А пока работу не ищешь, скилл атрофируется.

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

Почему я стал искать работу в ±2019 году? Во-первых, ни один из моих стартапов не принес мне миллиарда. Начали подходить к завершению обязательства по одному интересному, но малобюджетному проекту, а зарабатывать больше хотелось (к тому же я женился). Во-вторых, к моему немалому удивлению неожиданно обнаружилось, что каким-то совершенно непостижимым образом одна «никому не нужная» технология из моего стека является неожиданно очень даже нужной. Java куда-то начала сдавать, а крупные компании «полюбили» Go, который я полным ходом использовал для промышленных проектов. И я решил попробовать — почему бы и нет?

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

И вот спустя месяц меня просят присоединиться к собеседованию кандидата на Go. Для подстраховки, ну… или не знаю зачем. Я принял инициативу, и коллеги потом сказали, что «это было круто, уровень как в одной-большой-компании» (это был приятный комплимент, хотя я, честно говоря, не знаю, как там у этой компании). С тех пор я стал проводить их всегда.

Я почти сразу получил ответ, зачем задавать тривиальные вопросы. Очень просто. Примерно 9 из 10 кандидатов не знали языка. Они прочитали о нем в интернете, но что-то конкретное сделать не могли. Если бы я заранее знал об этой простой статистике, я бы не воспринимал в штыки попытки работодателей задавать мне по кругу одни и те же тривиальные вопросы. Для меня эта простая, но правдивая статистика стала большим сюрпризом.

Как мы обжигались


image

Начало собеседования. Тимлид просит рассказать о себе, рассказывает о нашем проекте. Беседа ладится, по всем параметрам — наш кандидат. Разговор затянулся, кандидат рассказал кучу профессиональных историй, мы уже начали строить планы по захвату Вселенной! И вдруг одна странная реплика. «Стоп! — подумал я. — Давайте-ка я спрошу его о чем-то простом.» И задал ему вопрос, как устроены слайсы в Go. Дальше был полный облом по всем простейшим вещам. Только что мы разговаривали про нагрузочное и интеграционное тестирование, и, оказывается, он не знаем что такое стек, или структура данных, или… Да, я реально разговаривал с людьми, которые не знают, что такое рекурсия и стек!

Потом столкнулись с таким во второй раз. Было очень больно.

После этого мы приняли решение начинать с азов, с простейших вещей, независимо от того, что кандидат написал в анкете. 30 минут вполне достаточно, чтобы принять решение — плавно и вежливо завершить беседу или продолжить общение дальше. Если кандидат продержался 30 минут и мы продолжаем разговаривать, значит, время потрачено не зря. Даже если он нам не подойдёт. Или мы ему. Даже если он не примет оффер и не будет с нами работать. Такая беседа почти наверняка будет интересной и взаимно полезной, приятной и неутомительной.

Поначалу было сложно в точности следовать правилу. Но, опалив брови еще парочку раз, пусть и не так сильно, мы влились в практику, и с моим тимлидом Денисом собрали отличную команду. Спасибо тебе, Денис, за бесценный опыт.

Практика, к которой мы пришли, оказалась общепринятой


Сейчас, работая в #CloudMTS, я вижу, что здесь применяется именно эта практика. Так или иначе, через ошибки все приходят к одним и тем же решениям. Это ещё раз подтверждает жизнеспособность используемого подхода.

Цель — да или нет. Программа минимум


От кого-то (возможно, от отца) я слышал такую легенду. Мол, когда Игорь Курчатов собирал команду и решал, кто будет с ним работать над сами-знаете-каким проектом, он лично принимал у кандидатов теорминимум. Возможно, это не так, ведь своим теорминимумом был знаменит Лев Ландау. А может быть, это правда. Это неважно.

Важно то, что нужно отчетливо понимать, для чего мы проводим собеседование. Какова цель? Что мы хотим выяснить? Моя история руководства малыми командами началась приблизительно в 2006 году. Оглядываясь назад сейчас, я понимаю, как точно и справедливо то, что я сейчас скажу.

Не надо устраивать из собеседования экзамен.

Вы никогда не узнаете все о человеке за одно собеседование. Люди слишком многогранны, список удивительных недостатков, мешающих работать, может занять несколько страниц. Все это невозможно выявить на собеседовании. Если хорошенько копнуть, завалить каверзными вопросами можно каждого. Но окажется ли хорошим сотрудником тот, кто ответит на все ваши вопросы? Не факт.

Тогда зачем мы проводим собеседование? Собеседуясь на роль разработчика, я столкнулся, как уже говорил, с попыткой меня проэкзаменовать. И зачастую это делали люди с меньшим опытом. Когда я сам стал проводить собеседования, то поймал себя на желании экзаменовать и заваливать кандидата вопросами, столь сложными, насколько сильна его квалификация. Порой, если кандидат сильный, это начинает походить на игру «где же он сломается». Своеобразная попытка найти, что он не знает. Это все не то.
Мы все чего-то не знаем.

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

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

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

Часто сложно понять, подходит ли кандидат, достаточно ли он хорош. «Да» или «нет». Задачу можно сильно упростить, если переформулировать вопрос. Вместо того, чтобы пытаться оценить кандидата по какой-то шкале компетенции, спросите себя: «Он готов завтра выйти на работу к нам? Хватит ли у него подготовки?». Здесь дать дискретный ответ намного проще.

Другие способы и практики проверки кандидатов


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

Кстати о них. Хорошее тестовое задание иногда занимает и пару дней фуллтайм, после чего крайне обидно получить отказ или вовсе тишину в ответ. Есть отличный компромисс — попросить кандидата предоставить любой свой опенсорсный проект, посмотреть его и предложить доработать. Так мы убедимся, что это действительно его проект, а кандидату не будет жалко потратить на него свое время.

Существует популярная отговорка — «я работал под NDA, проектов нет». Это лукавство. Я сам много лет работал под NDA и тоже так думал. А сейчас оглядываюсь и вижу почти десяток петпроджектов. Надо просто вспомнить, что они были, и выложить в сеть.

Недостаток компетенции vs неспособность драйвить результаты


Мне довелось поработать с очень разными людьми — среди них были не только ИТ-шники, но и ребята из строительства и производства. Судя по моему опыту, есть люди небрежные. Есть аккуратные. А ещё есть люди-паровозы, которые делают быстрее и больше. Какое отношение это имеет к ИТ? Непосредственное.

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

Уточнение для тех, кто не застал дискеты и перфокарты. 1985 год, новейший суперкомпьютер Cray-2, с жидкостным охлаждением:

image

Он обеспечивал пиковую производительность 1.9 GFLOPS.

iPhone 12 = 11_000 GFLOPS, в 5 тысяч раз больше, прямо в вашем кармане. Ни одна другая отрасль не дает таких возможностей, как ИТ, по прогрессу возможностей и их бытовой доступности. Говорят, что среднебюджетный смартфон имеет больше вычислительной мощности, чем было на всей планете в 1969 году. Это не значит, что их тогда было мало. Их было много. Но стало еще больше.


Есть компетенции, которые можно проверить на собеседовании. Но есть и те, которые проверить затруднительно. Компетентен ли кандидат, который «на пятерку» знает язык, отлично ответил на вопросы и всем понравился? Не факт. Потому что в программировании почти как в литературе. Знание языка программирования подобно знанию литературного языка, знание паттернов — знанию стилистических приемов. И можно точно сказать, что человек, который не умеет писать, профнепригоден.

Но наоборот это, увы, не работает. Если человек умеет писать, хорошо начитан, это не гарантирует, что он сможет сочинить роман или даже колонку в газету.

Каково решение? Например, дать кандидату отрефакторить и привести в порядок фрагмент, который, хоть и работает, но написан плохо. И посмотреть, что будет. Сможет ли он найти «кривизну»? При любом раскладе вы сможете сделать выводы. Но это уже история не про кандидата, а, скорее, про испытуемого.

При прочих равных нанимать тех, кто лучше пишет


Где-то видел такой совет: при прочих равных, нанимайте тех, кто лучше пишет. Это не значит, что нужно нанимать писателей. Дело в том, что тот, кто может написать связный текст, способен ясно выразить свои мысли коллегам, начальству, инвесторам, в документации, и… в коде. Ясное изложение текстом — признак ясных мыслей. Все просто.

Приведу пример. Допустим, есть идея перекрасить все пешеходные переходы в зеленый цвет. Абсурдно? Да. Имеет ли это значение? Нет. Попросите кандидата текстом описать преимущества и недостатки этой идеи и посмотрите, как он с этим справится.

Результат решения задачи поможет буквально «под микроскопом» рассмотреть сознание кандидата. Пусть не количественно, а качественно.

Однажды я нанял специалиста, в обязанности которого входили написание и поддержание документации по проектам. Не формальности всякие (что обычно техписы делают), а именно внутренние документы. Чтобы не было кучи салфеток с заметками и можно было зафиксировать на бумаге «ту схему, нарисованную мелом на стене». К сожалению, оказалось, что человек физически не способен самостоятельно написать более 500 байт текста. То же самое применимо и к задаче нарисовать схему. Ясное изложение схемами — признак ясного мышления и способности излагать мысли. Это важно.

Байас — наши программисты по определению умнее тех, кого мы собеседуем (нет)


Существует мнение, что «наши» разработчики по определению знают лучше. Выражается это в повсеместной практике приглашать на собеседование тех специалистов, которые должны оценить кандидата. А что если кандидат обладает не меньшей экспертизой, чем те, кто его собеседует, но придерживается иных взглядов? Очевидно, у собеседователя будет негативный байас по отношению к кандидату. Как любой байас, это плохо, потому что необъективно.

Избавиться от этого сложно и не всегда нужно. Но важно помнить, что он есть. Как и риск, что коллеги отсекут все новое/непривычное/отличающееся, а к вам в компанию попадет не крутой спец, а человек с похожими взглядами. Пример: если React фронт собеседует фронта, а собеседуемый осторожно говорит, что «вообще-то React — не торт», скорее всего, работу он не получит. А вдруг React и правда так себе?

О бизнес-аналитике


Мне довелось работать с Антоном Романюком, отличным бизнес-аналитиком, и он буквально «ломал» задачу, которой я занимался. Он нашел столько кейсов и граничных случаев, описал все это так, как не сделал бы тестировщик или кто-либо другой. Когда мне казалось, что «ну все, теперь чисто», он приходил и говорил «а что если вот тут — вот так?». Это было очень круто. На выходе получился безупречно работающий продукт с отличной документацией, выверенной, как юридический документ.

Бизнес-аналитика очень важна. Даже если этой должности нет, в каждой команде обязательно должен быть кто-то, несущий бремя аналитика. Часто это product owner, или РП, или даже простой разработчик. Ведь должность аналитика бывает довольно редко, а если и есть, под маской аналитика может скрываться продвинутый техпис. Я сталкивался со случаями, когда роль бизнес-аналитика отчасти брал на себя дизайнер. Неожиданно, правда?

Я считаю, в каждой команде должен быть кто-то, кто обладает способностью погрузиться в задачу предметно, глубоко и комплексно, понять вводные, упорядочить их в воображении и кристально четко видеть, что должно получиться. Сформулировать это понятно и доступно для других членов команды. Если в команде более одного человека с такой способностью, мы получим жаркие споры и дискуссии. Это неплохо! Но если нет ни одного, проект будет пробуксовывать даже с самыми сильными разработчиками.

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

Мой список вопросов на русском с комментариями


Выше я писал о том, что собеседование необходимо начинать с азов. Напомню мои тезисы:

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


Этот список вопросов не исчерпывающий. Здесь есть как очень простые (например, «что есть стек?», потому что я видел тех, кто этого не знает), так и более хитрые. Use at your discretion, как говорится. Для себя я понял, что держать его открытым во время собеседования достаточно удобно. И после каждой встречи с кандидатами я дополняю его чем-то новым.

Начинайте с простых вопросов, чтобы прощупать уровень. По возможности переходите к сложным. Практика показывает, что сильные специалисты даже на простых вопросах расскажут что-то интересное.

Помните самые главные правила:

  1. Составьте заранее список того, что есть «профпригодность» для этой роли и этой команды. Кандидат по этому списку что-то не знает? Ок, один раз можно сделать поблажку, но если два пункта мимо — однозначно нет. Это «килл лист», фильтр, но не способ оценить уровень.
  2. По тем вопросам, которые не входят в килл-лист, руководствуйтесь правилом: если знает — это плюс, если не знает — это ничего не значит.
  3. Когда чувствуете, что вас водят за нос — на ровном месте начинайте копать в детали, задавать более глубокие и уточняющие вопросы. Правда моментально проявляется, как вода на песке.

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

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


Секция 1, системный минимум, начальные вопросы


  • Что такое стек? Что такое рекурсия?
  • Как в Go вы можете повлиять, попадет ли что-то в стек или хип (кучу)?
  • Что такое структура данных? Что такое переменная? Что есть регистр? Указатель?
  • Поток ОС, процесс ОС — что такое, чем отличается горутина? Расскажите о памяти в данном контексте?
  • Что такое контейнеры, ВМ? отличие ВМ от контейнера, виды гипервизоров?
  • Как ОС управляет памятью? Страницы, виртуальная память?
  • Иерархия памяти. Фенсинг, барьеры, зачем?
  • Ядро ОС, syscalls, cgroups, systemd; systemd vs. docker?
  • Как убить процесс Linux по имени? Еще какие способы? Недостатки и преимущества? Что такое jobs?
  • Как сконфигурировать доступ SSH по ключу на свежепроинсталлированный Linux?
  • Как посмотреть логи в Linux? Второй способ?
  • Что такое дедлоки?
  • Race conditions?
  • Идемпотентность?

Секция 2, минимум по Golang


  • Синтаксис switch — чем отличается от других языков?
  • Система типов

— Type switch
— Reflection

  • Slices (90% кандидатов отсеиваются на этих вопросах)

— Что есть слайсы?
— Что есть массивы?
— Три способа создать слайс? Создать слайс с размером 0 и емкостью N?
— Слайсы передаются в функцию по указателю, по значению или как-то еще?
— Append — пожалуйста, расскажи, как это напишешь? Как это работает? Насколько увеличится массив? Капасити пустого слайса? Аппенд к очень большим слайсам?
— Удалить элемент слева (в начале)? В середине?
— Есть бесконечный цикл, новые элементы аппендятся, первый элемент постоянно удаляется.
— Как много памяти съест такой слайс со временем (рассказать в деталях)?
— Вы передаете слайс в функцию, аппендите элемент и возвращаете слайс обратно —будет ли возвращенный слайс иметь тот же самый нижестоящий массив?
— Вы передаете слайс в функцию, аппендите элемент и возвращаете слайс обратно — будет ли возвращенный слайс использовать тот же нижележащий массив, что и оригинальный слайс? (детали)
— Есть слайс s1 с 50 элементами. Ты берешь s2=s1[30:40], затем анмаршалишь JSON в s2.
— Можно ли ожидать, что элементы 30..40 в s1 проапдейтятся, или что произойдет?
—Можно ли взять пойнтер на элемент слайса? Почему?

  • Строки в Го

— Иммутабельность
— Руны
— Как итерировать по рунам?
— Оверхед использования рун, и вообще анализ в деталях

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

— Что такое горутины, потоки? Сколько и каких создается по умолчанию?
— Что они из себя представляют? Как много памяти занимают? Что если нужно больше стекового пространства?
— Как горутины мапятся на потоки ОС и на ядра процессора?
— Можно ли принудительно завершить горутину извне ее? Хорошо, вам правда это нужно, как вы решите эту задачу?
— Могут ли быть утечки горутин? Возможно ли это на практике? Приведите пример, как это может произойти и как вы будете устранять причину?

  • Каналы (продолжение про конкурентность)

— У вас есть канал, из которого читаете, и некоторая блокирующая операция ввода-вывода, например сетевой сокет. Расскажите, как вы сможете объединить обе операции чтения в один общий цикл, так что бы не было ситуации блокировки и игнорирования данных в канале?
— Еще раз — что есть каналы по сути, какие бывают (два вида)?
— Вы пишете в небуферизированный канал, из которого никто не читает — что произойдет?
— Что такое блокировка (по существу)?
— У вас есть канал, несколько горутин читают из него. Вы записываете сообщение в канал.
— Какая горутина получит его?
— Что делать, если вам нужно, чтобы получили все?
— Что если количество читающих горутин переменное, как вы решите эту задачу?
— Что произойдет, если вы будете читать из закрытого канала?
— Как это может быть с пользой использовано? Есть ли стандартные библиотеки языка, работа которых построена на этом поведении каналов?
— Что произойдет, если вы попытаетесь записать в закрытый канал?
— Хорошо, но предположим, что вам нужно точно убедиться, что этого не произойдёт. Как вы поступите, есть ли какие-то методологии по этому поводу? Предположим вы не можете ничего гарантировать, но как вам обезопаситься от паники при записи в канал?
— Range над каналом
— Вы записали некоторые данные в буферизованный канал, и закрыли его. Можете ли вы прочитать эти данные обратно?
— У вас есть канал и вы хотите посылать в него данные только в том случае, если он готов их принять. Вы не можете позволить себе блокироваться и ждать записи. Как вы поступите?
— Опишите два или три варианта, как можно поступить, и сравните их. Что если канал не буферизован?
— Вы можете позволить себе заблокироваться на операции с каналом, но не более чем на 5 сек — как вы это реализуете?
— У вас есть библиотечная блокирующаяся функция, и без таймаута, но вы не можете себе позволить блокироваться без таймаута. Как вы сделаете обертку над ней, чтобы обеспечить таймаут?
— Можно ли определить, что канал полон?
— А можно ли определить, что он пуст? А если у нас есть канал для передачи данных, и перед завершением горутины хотим убедиться, что он пуст. Каков корректный способ это обеспечить?
— Почему “Uber best practices” рекомендует устанавливать емкость всех буферизованных каналов в 1 или иначе очень хорошо подумать, если там любая другая цифра? С чем это связано?
— Можно ли изменить размер буфера канала?
— Хорошо, вам очень это нужно, как вы реализуете это?
— Какие виды данных можно передавать через каналы? Можно ли передать другой канал? Пустую структуру? Зачем это может быть нужно?
— Всегда ли эффективнее передавать через каналы данные по указателю, или по значению — проведите сравнение и анализ.
— Как можно имплементировать RPC поверх каналов? То есть как коммуницировать с N горутин и получать ответы асинхронно от каждой отдельно?
— Как реализовать приоритезацию среди набора каналов? (Это самый хитрый вопрос. Если кандидат успешно расскажет как — он молодец.)

  • Синхронизация (конкурентность, часть 3)

— Что такое waitgroups?
— Мьютексы — что это, что под капотом, какие виды бывают?
— Контексты: виды контекстов? Какой от них прок? Предположим, контекстов нет, — как вы имплементируете их сами? Как остановить net/http сервер?
— Семафоры и мьютексы: как имплементировать семафор с помощью канала? Как использовать канал вместо мьютекса?

— Мьютексы vs каналы: что лучше, что по этому поводу говорит «официальный Го» и что типично в проектах? Преимущества и недостатки — провести анализ-сравнение. Какие еще есть средства взаимодействия (перечислить хотя бы еще два)?

— Deadlocks: что представляют собой, как их детектировать, как понять, что это случилось? Как искать причину, дебажить? Как с ними бороться, стратегии по предотвращению? Как должна вести себя программа, если это произошло? Могут ли быть при использовании каналов?
Могут ли быть при использовании внешних ресурсов? Является ли умышленная блокировка горутины дедлоком? Привести примеры, как сделать дедлок в Go.

— Что такое гонки? [Задаем все те же вопросы, что и про дедлоки]

  • Сборщик мусора и управление памятью

— Что это такое и как он работает?
— Можно ли его остановить, отключить, форсировать выполнение?
— Можно ли так написать программу, чтобы сборщику нечего было делать, или хотя бы минимизировать его работу? Какие паттерны наоборот приводят к избыточной нагрузке на сборщик?
— Стек vs хип (куча).
— Аллокация в стеке или на куче — от чего это зависит, как на это можно влиять? Escape analysis?
— Как мониторить циклы сборщик и расходование памяти? Каковы характерные графики?
— Как понять, что у вас утечка памяти?
— Как утечку дебажить (искать причину)?
— Как отследить утечку горутин? Пример — как такое может случиться? Как посмотреть количество горутин?

  • Maps

— vs. hash set?
— Что такое хэш-функция? … (а здесь место вашему воображению, читатель — см. комментарий в начале списка!)

  • ООП

— Embedding?
— Interfaces?
— “Exported” vs “not exported”?
— … (а здесь место вашему воображение, читатель — см. комментарий в начале списка!)

  • Ошибка

— Как создать новую ошибку?
— Новый тип?
— Проще, например, из строки?
— Как отследить, что возвращается конкретная ошибка?
— error.Is(), error.As();
— %w в формате строки?

  • Управление репозиториями, проектами и зависимостями

— Управление зависимостями.
— Go mod.
— Вендоринг зависимостей.
— Проксирование и кэширование.
— Использование кэширования как неявного вендоринга.
— Чем модуль отличается от пакета?
— Допускает ли Go циклические импорт? Почему?
— Нам нужен циклический импорт — что делать?
— Использование интерфейсов для инверсии зависимостей?
— Способы организации кода?

Секция 3, форматы данных


  • JSON
  • Формат gob — что это?
  • XML
  • YAML
  • protobuf

— Генерация?
— Где используется?
— Как еще используется, кроме grpc?

Секция 4, базы данных


  • Основное

— Реляционные?
— Нереляционные?
— Какова разница? Можно ли все виды задач решить в одном или другом классе БД?
— Уровни изоляции данных: Read uncommitted? Read committed? Repeatable read? Serializable?

  • 2PC (заодно пусть расскажет что это): Задачка про транзакцию над несколькими внешними БД, можно пример про отпуск и билеты.

— Consistency?
— Eventual consistency?
— Индексы — какие бывают? По назначению? Внутреннее устройство? Имплементация внутри, какие бывают варианты имплементаций? Индексы для геоданных?

  • Репликация

— Шардирование?
— Мастер / слейв?
— Какие еще варианты бывают?
— Ограничения и сравнительный анализ?

  • Отказоустойчивость

— Инструменты?
— Сплит брейн в БД?

  • Redis, Postgres, MongoDB, et al

—Какие библиотеки вы используете (по каждой БД которую говорит что использовал (способ проверить использовал ли — если нет, сразу тут падает))?
—Отличия, особенности, и т.д.?

  • PostgreSQL

— Предназначение pgbouncer?
— Типы пуллинга?
— Ограничения?
— Производительность?
— Клиентский пуллинг в Го?

Секция 5, сети


  • Что такое L2, L3, L4, L7? Детали и примеры.
  • IP адреса, маски, DNS?
  • VPN и бриджевание L2 или L3 — в чем разница?
  • Что такое ARP-запрос?
  • Вы вводите в строке браузера google.com и нажимаете Enter — расскажите за 3 минуты в деталях, что дальше будет происходить? (с этого можно начать)
  • HTTP
  • Как такой запрос выглядит?
  • TCP?
  • TLS?

  • UDP?
  • Расскажите о преимуществах и недостатках, проведите сравнительный анализ, приведите примеры, где использовали бы одно, а где другое.
  • Что такое порты? А сокеты? В чем разница?
  • Расскажите что такое RPC?
  • Что такое REST?

— OpenAPI, Swagger?
— Чем REST отличается от RPC?
— Может ли REST быть имплементирован не поверх HTTP? С примером?
— Возможно ли кэшировать REST? RPC?
— Балансировка нагрузки, RPC vs. REST?
— RESTful, REST-like — что это значит?

  • GRPC

— Что это, чем отличается (кроме использования protobuf)?
— Особенности балансировки?

Секция 6, брокеры, очереди сообщений


  • Общее

— push или pull?
— Режимы доставки at least once, at most once, exactly once?
— А вообще возможен ли 1= (exactly once)?
— Что такое персистентность?
— Расскажите о идемпотентности?
— Расскажите о split brain?
  • Паттерны

— Multicast / fanout, job distribution?
— Продолжите список

  • Kafka

— Партиции
— Оффсеты
— Персистентность
— Consumer groups
— Наиболее распространенные библиотеки, и расскажите об опыте использования?

  • AMQP / RabbitMQ (если он работал с ним)
  • NATS (если он работал с ним)
  • NATS Streaming / JetStream (если он работал с ним)
  • и т.д.

Секция 7, инфраструктура и архитектура


  • Docker

— Что такое Layers?
— Что такое Containers?

  • Kubernetes (или альтернативы)?
  • Шаблоны микросервисной архитектуры?


— Монолит vs микросервисы?
— Стоит ли делать новый продБукт монолитным — преимущества и недостатки?
— Как монолит может упереться в потолок производительности, и что делать?
— Какие могут быть подходы при распиле монолита на микросервисы?

  • Межсервисное взаимодействие

— Синхронное?
— Асинхронное?
— Событийное взаимодействие?
— Сага, два вида. Конечный автомат, персистизация состояния (в контексте оркестрационной саги)?
— 2PC?
— Eventual consistency vs. strict consistency — детали?
— CQRS, event sourcing?
— Audit log?
— Варианты интеграции, плюсы и минусы?

Секция 8, алгоритмы


  • Деревья

— B-tree?
— Trie, prefix tree?
— Другие виды?

Подведем итоги


В одной статье на Хабре уже рассказывали про оптимизацию процесса найма. Автор говорил, что для каждой компании и команды, для каждого тимлида и продакт оунера в разные моменты времени оптимальными могут быть разные способы. Предлагаю на этом и закончить.
Главное, чтобы каждая команда была дружной и эффективной.


image

Комментарии (52)


  1. LARII
    15.01.2022 00:18
    +28

    Каждый вопрос - доклад минут 20-40.


  1. Nikita_Churakov
    15.01.2022 01:32

    Крутая статья!


  1. vgogolin
    15.01.2022 01:52
    +2

    Теперь у вас появятся много разработчиков, кто знают ответы на все ваши вопросы ????


    1. kibergus
      15.01.2022 12:03
      +2

      Если правда знают - можно брать.


    1. Spunreal
      15.01.2022 18:08
      +2

      Так тут как раз ответов нет. А вопросов так много, что либо это учишь долго, либо почти всё забудется перед собеседованием. Так что тот, кто будет знать ответы на эти вопросы, скорее всего нормальный специалист :)


    1. Brainslam
      15.01.2022 23:09

      Поверь, все равно не появятся)))) есть куча ресурсов, где учи - не хочу, как говорится)) но никто это не делает)) а жаль)


  1. AirLight
    15.01.2022 06:30
    +6

    Зачем про управление памятью на уровне ОС? Никогда не слышал таких дискуссий у бэкендеров!


    1. elisoff
      15.01.2022 12:12
      +2

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


    1. souls_arch
      16.01.2022 05:55
      +3

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


  1. fredrsf
    15.01.2022 07:09
    +36

    Приведу еще один вариант «плохого» вопроса. Например, мы собеседуем разработчика на Go и просим его рассказать, как сделать семафор с помощью канала.

    — Семафоры и мьютексы: как имплементировать семафор с помощью канала?


    1. elisoff
      15.01.2022 21:38

      Вся правда по МТС в одном вопросе?)


    1. latitov Автор
      16.01.2022 16:28
      +3

      Автор здесь: да, поймали меня. Так вышло потому, что сначала был список вопросов, который пополнялся. Он и сейчас есть, на гитхабе, на английском правда. Статья была дописана сверху него, как бы. Таким образом, здесь нет противоречия. Да, такой вопрос есть. И да, я считаю что это плохой вопрос. Как говорил Ларри Уолл - "1 - я всегда прав, 2 - я могу изменить свое мнение".

      Там же написано, что цель статьи - не дать вам чеклист готовый! Она как раз об этом. Я поражен сколько много комментов, и, пользуясь случаем хочу ответить тем, кто удивляется тем что вопросы какие-то может не нужны, или неуместны..... Друзья! Эта статья - мой личный опыт (история рассказанная за пивом), вкупе с некоторой моей личной шпаргалкой. И как и всякую не свою шпаргалку, использовать все это буквально точно не надо.

      Скорее, это про определенную мысль, которая пронизывает статью от начала до конца, о отношении к самому действу под названием собес. Что это? Для чего он? А список вопросов, вы если что, и сами напишите. Этот список - просто пример, рассматривайте его так, и не более чем так.

      И еще. Да, у нас в МТС высокий уровень. И да, мы считаем что разработчик бэка должен отличать L2 и L3. И точно должен знать про память.

      Кто-то писал, что "а что я могу почерпнуть отсюда". Окей, если вы прочитали, это заставило вас задуматься - вы уже что-то почерпнули.

      Желаю всем хорошего и продуктивного 2022 года!


      1. latitov Автор
        16.01.2022 17:18
        +1

        Еще раз, чтобы не было разночтений:
        - список вопросов который всем так не понравился - моя личная шпаргалка.
        - Вам, при использовании моей шпаргалки, возможно не надо пользоваться ей буквально.
        - список не является "официальным чеклистом для приема на работу" куда либо - это моя личная шпаргалка.
        - Эта шпаргалка - прежде всего не для тех кто ищет работу, но прежде всего для тех кто проводит собеседования. Материал для вдохновления, чтобы написать свою. Возможно даже, для другого языка (!). Смотрите шире и более обще.
        - Несмотря на критику, под каждым словом подписываюсь, так что не надо тут "накидывать косвенно" на МТС. Не согласы - пишите мне лично "ты написал дичь", и (!) содержательно аргументируйте почему.
        - И САМОЕ ГЛАВНОЕ: лучший способ пройти любое интервью - по чесноку знать то, на что претендуете. Тогда не придется ничего заучивать.


  1. micbal
    15.01.2022 07:55
    +2

    Если востребованы знания столь низкого уровня, наверно речь идет о высоконагружаемых и высоконадежных проектах с неограниченным временем разработки и тестирования. Однако в большинстве случаев нужно было все сдать уже вчера, и слайс используется в отличие от массива только потому что он расширяется. Возможно лучше будет например способность найти оптимальное количество абстракций проекта под задачи бизнеса? Или исходя из перспектив тип фреймворка, ORM или RAW SQL, форматы обмена по шинам и т.п.? Вопросы вроде на синьора, но для синьора на мой взгляд важнее, что я написал. А подход к собеседованию самый адекватный из тех что я видел!


  1. silentz
    15.01.2022 09:00
    +2

    Раньше когда сам только ходил на собеседования не понимал зачем задают такие простые вопросы. С недавних пор сам начал собеседовать и понял - 80% не знает и минимума, хотя опыта якобы несколько лет. До вопросов со звёздочкой или философских вопросов ещё не доходил - не было такого, чтобы кандидат отвечал на вопросы так быстро и ясно, что хотелось ему позадавать более "сложные". Правда и собеседовал на джунов и мидлов. Хотя, казалось бы, основы у них должны от зубов отлетать.


  1. elisoff
    15.01.2022 12:10
    +3

    Все читал и думал - а это точно про МТС? А потом когда дело дошло до списка вопросов и чек листа после прохожденя которого якобы человек попадает в МТС понял что точно не про МТС.


  1. onets
    15.01.2022 12:41
    +8

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

    Чаще всего перекладываешь json в базу и обратно. И раскапываешь доку на внешний сервис, с которым тебе надо интегрироваться. Периодически возникают проблемы производительности. Но никакое управление памятью потоками и процессами оказывается не причем. А тупо в семафор случайно передают ноль в качестве периода срабатывания, что и грузит проц на 99%.

    Так что все сводится к повторению теории перед собеседованием. В надежде угадать какие именно вопросы будут спрашивать именно на этом собесе.


  1. ALexhha
    15.01.2022 12:44

    IP адреса, маски, DNS?

    VPN и бриджевание L2 или L3 — в чем разница?

    Что такое ARP-запрос?

    А зачем это знать бекендщику ?


    1. elisoff
      15.01.2022 14:18

      Особенно это - " VPN и бриджевание L2 или L3" , в этом вопросе ка не ответь все может быть неверно.


  1. Jammarra
    15.01.2022 15:04
    +20

    И эти же люди потом жалуются на кадровый голод)

    задача собеседования узнать что человек сможет решить поставленую задачу. Для этого достаточно спросить какие задачи он решал, как и посмотреть его резюме.

    все остальное какое то страдание фигней имхо.

    Ну типо есть куча компаний где я даже скрининг певональный не прошёл. Ибо не помню какое там определение транзакции в учебнике. Или структуру tcp пакета.

    Но не было ещё ни одной компании где бы при увольнении меня не уговаривали остаться и не делали контр оффер. Потому что работать это не языком чесать и умеет не каждый. А любую справочную инфу можно посмотреть внезапно в справочнике.

    Зп при этом во всех компаниях +- одинаковая

    Хотя на 150-200 тысяч долларов в год возможно и стоит поучить такой список. Только вот такие зп и мтс? Серьезно?)

    В целом почти что любой из предствленных вопросов требует подготовки в пару дней. Вдумчивого изучения например RFC. А и тянет как минимум на полноценную статью на хабре.


    1. GarfieldX
      15.01.2022 21:48
      +1

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

      И вообще собесы для меня полная катастрофа, а отпускать так же не хотели.


    1. latitov Автор
      16.01.2022 17:06

      Статья как раз о том, что возможно НЕ НАДО спрашивать про определение транзакции, или про труктуру пакета. Вы, для себя, для своего проекта, должны определить что точно и без вариантов должен кандидат знать. На все остальное можно закрыть глаза.

      Важно ли для вашего проекта знание структуры пакета? Да или нет? Если нет - это не попадает в список. Если да - тогда да. И так по каждой позиции.

      Данный список - моя личная шпаргалка, чтобы самому уже не путаться (т.к. когда проведешь два собеса в день, (а и так было), то уже не помнишь что спрашивал что нет), и это не официальный список МТС. Более того, наверняка многие коллеги со мной бы поспорили, по этому списку.

      Эх, вот уж этот список


  1. vadimbereza
    15.01.2022 16:22
    +7

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

    В любом случае, было бы интересно узнать, какой процент действующих разрабов МТС сможет ответить на весь этот список и почему они все еще работают в МТС


    1. Jammarra
      15.01.2022 16:52
      +2

      Основной вопрос в том, а зачем оно нужно проходить такое собеседование. В мтс прости господи.

      Яндекс и Тинькофф ладно с натяжкой, и очень многими но и если, но потянет. Но мтс то куда)

      почему все так любят бездумно копировать Гугл и нетфликс. Тыря вопросы. Без понимания почему те могут себе такое позволить.

      Я реально не понимаю зачем кто то туда пойдёт и будет готовится с таким подходом? Только совсем неудачник какой то без работы с кучей свободного времени.

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


      1. vadimbereza
        15.01.2022 17:02

        Ну этот список вопросов, кстати, никак не копирует гугл и нетфликс, в отличии от яндекс и тинькофф, там все таки литкод, а здесь просто слишком хардкорный и длинный (для такой компании) список вопросов, который возможно и может оценить кандидата лучше, чем проверка задачек на алгоритмы


        1. Jammarra
          15.01.2022 18:54
          +1

          Да я большую часть этих вопросов уже не раз видел на гите по запросу interview questions

          просто оно идёт допом к задачам по алгоритмам


      1. latitov Автор
        16.01.2022 16:50

        Вообще-то, это мой личный список вопросов. Моя личная шпаргалка. Ну а поскольку я работаю в МТС, то если вы придете к нам на работу устраиваться, и вам "повезет" что собеседовать буду я, то я задам эти вопросы... или не эти, или другие. Но это точно не копирование кого-то. Если у кого-то так же (а мне уже говорили об этом, как комплимент), ну значит крутяк, я мыслю похожим образом, и для вас дорогие читатели выше вероятность что это валидный подход.


        1. Jammarra
          16.01.2022 18:19

          не разраб на го я. Так пофлудить зашёл в тему.


    1. latitov Автор
      16.01.2022 16:47

      90 минут достаточно. Если на вопросы есть корректные ответы. Если нет - 30 минут вежливости. Ну час.

      Читайте внимательнее :) все вопросы не надо задавать. Это не чеклист. Это шпаргалка.


  1. via-site
    15.01.2022 16:36
    +7

    Хорошая и логичная статья, кроме списка вопросов в самом конце. Похоже что автор сам себе противоречит.


    1. latitov Автор
      16.01.2022 16:45
      -2

      Посмотрите мой ответ на это выше. Да, есть такое. Сорян гайз. Выше коммент почему так, и как так :)


  1. HellWalk
    15.01.2022 16:53
    +1

    Только что мы разговаривали про нагрузочное и интеграционное тестирование, и, оказывается, он не знаем что такое стек, или структура данных, или… Да, я реально разговаривал с людьми, которые не знают, что такое рекурсия и стек!

    Потом столкнулись с таким во второй раз. Было очень больно.

    Если мне два кандидата, покажут свои домашние проекты, на одном авто-тесты с 90+% покрытием и CI/CD, но он не знает всего вышеперечисленного, а у другого нет авто-тестов, но в теории он прям все знает - я выберу первого.

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

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

    P.S. Конечно, в программировании много специфичных сфер. Но в веб-бекенде, где под капотом по микросервисам гоняются json-чики - самой сложной задачей оказываются элементарные вещи: чтобы API возвращало то, что написано в документации, чтобы отправленные данные, пройдя через 10 микросервисов, не сломались по дороге. Казалось бы, ничего сложного - просто внимательно пишите авто-тесты, просто настройте CI/CD, просто не ленитесь обновлять тесты под изменившуюся логику, но... 90% команд этого не могут. И получаем бесконечные баги-баги-баги...


    1. micbal
      15.01.2022 19:23
      +1

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


      1. HellWalk
        16.01.2022 14:02

        На коммерческих проектах бизнес решает оплачивать написание тестов или не оплачивать

        Вы лишь доказали, то, что я написал)

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

        Бизнес нужно спрашивать что ему нужно, а вот как делать - решают программисты.

        Не всегда процент покрытия тестами говорит о качестве кода.

        Как там говорят - кто борется, может проиграть, кто не борется, тот уже проиграл.


    1. silentz
      15.01.2022 23:32
      +1

      С чего вы взяли что чел не скопирастил этот проект и зарефачил названия классов чтобы сложнее было гуглить оригинал


      1. HellWalk
        16.01.2022 12:59

        Если у человека есть личные проекты (и они не в виде Hello World - это, понятное дело, ни о чем) - то большую часть собеседования я бы обсуждал именно их. Человек, который чужой проект выставляет за свой - очень быстро поплывет при обсуждении.


    1. kyb27
      16.01.2022 13:36

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

      И тесты, не гороворя уже о CI/CD, могут быть не нужны. Код дает нужный результат, если что-то не так автор отравит все в помойку и начнет заново. От автора не требуется ни поддержка ни забота о будущих поколениях.

      Так что судить о навыках по такому источнику может быть как минимум неэффективно.

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


    1. Bromles
      16.01.2022 15:28

      Просто есть люди, которые пишут нормальный код, а есть пишущие 100500 видов тестов вместо кода

      Особенно требовать 90% покрытия и CI/CD в петах смешно. Человек, по вашему, пет пишет, чтобы те же 90% времени потратить на тесты, или, чтобы научиться с чем-то новым работать, что-то интересное ему освоить и сделать (что подразумевает написание кода)?


    1. latitov Автор
      16.01.2022 16:44

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

      А у вас есть показать, что вы сделали? У меня - есть. Но есть не у всех.

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

      Если у вас есть знакомый, который может показать свои проекты, с тестами и CI/CD, то может и тратить время вот на это все и не надо. Но таких знакомых на пересчет пальцев, обычно.


  1. ToSHiC
    15.01.2022 19:24

    • Строки в Го

    И задача на понимание юникода: как сравнить 2 строки?


    1. latitov Автор
      16.01.2022 17:20

      Да, там можно еще многое добавить, спасибо!


  1. AzIdeaL
    15.01.2022 20:36

    А статья-продолжение будет?

    Просто, не понял: зачем лом гнуть?!!


    1. latitov Автор
      16.01.2022 17:22

      Хм. :) То что я хотел сказать - сказал. Детализируйте плз какого продолжения вы ждете, и я могу даже спираль из лома скрутить, ток подать, и в среде аргона лампочку сделать!


  1. GarfieldX
    15.01.2022 21:20
    +2

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

    Вопросы в конце - дичь.


  1. Vladi4
    15.01.2022 23:08
    +2

    Какой то диссонанс между названием статьи и списком в конце. И много таких, кто прошёл все уровни этого списка?


  1. srgsrg1901
    15.01.2022 23:08
    -1

    По опыту, разработчики зачастую IP от порта отличить не могут, какая там модель osi? Может мне конечно так везет.


  1. igosja
    15.01.2022 23:08
    -1

    Мне приходилось несколько раз проводить технические собеседования, никогда не понимал вот таких бесед по часу-два с кандидатами.

    Если кандидат "идиот", это будет понятно сразу. То же работает в другую сторону - если человек разбирается в теме и его можно садить писать код, это тоже сразу видно. 10 минут достаточно, чтобы ответить кадровику по поводу оффера и примерной зарплаты.

    А вот эти все "напишете мне сортировку пузырьком маркером на доске" - это вопросы ради вопросов.


  1. nikandfor
    15.01.2022 23:08

    Вроде текста много, основная мысль понятна, но что я могу почерпнуть и применить я так и не понял.


  1. Arm79
    15.01.2022 23:08

    И что, каждый разработчик должен все это знать и выдать на собеседовании? И вы реально к вопросам начального уровня отнесли знания ядра OS и алгоритмы работы менеджера памяти OS?

    Секция 8 озаглавлена как программы, но вопросы там по разновидностям деревьев. Опять таки - если вы не разработчик систем управления данными, то зачем вам это?

    Поймал себя на мысли, что без подготовки ответил примерно на половину этих вопросов. Наверное, в вашей классификации я даже на Джуниора не тяну )


    1. HellWalk
      16.01.2022 17:18

      Компания сжалится и вышлет вам оффер с зарплатой чуть выше джуна. Ну а что вы хотели - вы ведь еще столько не знаете!


  1. kyb27
    16.01.2022 13:48

    У меня возник только один вопрос что такого плохого если кандидат будет знать заранее какие конструкции языка и алгоритнмы наиболее востребованы для конкретных вакансий?
    Разместить ссылки со списками рядом с вакансиями, пусть кто вспомнит, а кто выучит. И задавать на собеседовании задачки про наиболее характерные ситуации полученные по анализу ревью кода.
    Ведь тот же теорминимум состоял из вполне конкретного списка тем, про них знали и могли готовиться. И никого это не смущало.


  1. Nialpe
    17.01.2022 09:44

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