Ремарка - речь пойдет о 98% собеседований в постсоветском пространстве на позицию Java Developer.
Начну вот с чего: знание Collections Framework, его иерархии наследования, внутренней работы HashMap и количества примитивов в языке - никак, совсем никак, не может дать представления о работоспособности человека.
- Фу, какая банальщина, все и так всё понимают. Такие вопросы на собеседованиях дают представление о базовых знаниях человека, а на остальную работу смотрят в период испытательного срока.
Что же, с таким мнением я сталкивался неоднократно и не могу сказать ничего против, но тем не менее, приглашаю вас порассуждать о теме собеседования и разобраться, что с ними не так.
Вот пункты, которые, на мой взгляд, должны лежать в основе построения плана собеседования:
Работа разработчика состоит из 40% кодинга и 60% рассуждений, размышлений и попыток понять и вместить задачу, выбрать оптимальный алгоритм ее решения. И я не говорю о созвонах, декомпозиции и обсуждении предстоящего спринта и т.д. и т.п. В таком случае кодинга остается процентов 20.
Без грамотного и прозрачного процесса коммуникации между членами команды, проекта не получится. И к сожалению, какой бы прекрасный не был тимлид и ПМ, если разработчики не умеют общаться и понимать, какую информацию важно озвучивать команде, что нужно спрашивать, а что можно загуглить, у проекта будут проблемы.
Языки, фреймворки, библиотеки, базы данных и прочее - это всего лишь инструмент для решения проблемы, и он должен быть подобран под задачу, а не наоборот.
Теперь немного подробнее. Первый и второй пункт очень тесно взаимосвязаны друг с другом: часто приходится уточнять нюансы и задачи у тестировщиков, заказчика, аналитика… И я надеюсь никто не будет спорить, что пресловутые Soft Skills, умение задавать вопросы, понимать другого человека - очень сильно помогают осознать что именно ждут от вас и какой итог хотят видеть от проделанной работы. И в процессе осознания задачи и декомпозиции ее на подзадачи участвует много людей, как правило. А тот момент, когда вы останетесь с задачей один на один и приступаете к выбору инструментов ее решения наступает после длительного мыслительного процесса и процесса взаимосвязи между членами команды.
- БАНАЛЬНО, это все и так зна…
Ну подождите, может это и банально, но почему тогда в большинстве собеседований даже нет намека на попытку дать возможность человеку проявить свои навыки в декомпозиции задачи и подбору алгоритмов для ее решения? Почему мы сосредотачиваемся сразу на разнице между LinkedList и ArrayList?
Но в тот момент, когда мы остались с задачей наедине, код не начинает тут же появляться в нашей IDE. Конечно нет, даже тут приходится брать ручку или фломастер и рисовать диаграммы взаимодействия тех классов и методов, которые мы собираемся написать. В этот момент приходит осознание, как лучше реализовать бизнес логику, может быть правильнее потратить время на SQL запрос, или обработать данные в коде, стоит ли тут использовать наследование или композицию и т.д и т.п. И так, шаг за шагом, мы разматываем клубок и понимаем нюансы задачи и пазл собирается в картину. И даже тут старший товарищ, заметив ошибку, может невольно подвести вас к тому, что все рассуждения неверны, по типу ”””тут надо использовать HashTable, потому что она намного лучше и круче и вообще молодежнее, чем HashMap (Шелдон с табличкой --САРКАЗМ--)”””
Если мы сильно упростим и разделим наши вопросы на две категории, то это будут вопросы об ошибках и неточностях в бизнес-логике, которые, как правило, нужно обсуждать коллективно. И вопросы, которые стоит сначала погуглить, поискать решения, попробовать реализовать самому, а потом просить помощи (это я говорю сам себе, простите меня все, с кем я работал и не следовал этому важному правилу). Да, тут тоже уходит так много времени, совсем не на кодинг. Во всём этом ПРОЦЕССЕ знание языка и стандартной библиотеки, с которой он поставляется - далеко не на первом месте!
Конечно, я не имею в виду, что мы не должны этого знать. Но на 8-ми собеседованиях из 10-ти так и подмывает задать вопрос: «А вы-то сами имеете опыт работы с многопоточностью? Вы это спрашиваете, потому что на проекте приходится работать с этим?» Но ты молчишь и отвечаешь на вопросы о разнице между мониторами, мьютексами и радиоволнами...
Критикуешь - предлагай. Предлагаю: Давайте возьмем реальную бизнес-задачу и попросим человека рассказать, как бы он работал над ней. Послушаем какие вопросы он задает, как работает его мышление. На какие подзадачи он разобьет свое решение и почему? Если он на чем-то стопорнулся, спросим его, а чтобы он загуглил (да-да, почему на собеседованиях делают вид, что гугл взорвался, а stackoverflow теперь только на Иврите? Такого вопроса я вообще ни разу не слышал)? Если кандидат не знает ответа, как бы он его искал? Почему в одном случае стоит обратиться к коллеге, а в другом к строке поиска. Думаю многие понимают, что дает такое общение, оно показывает какими паттернами мыслит кандидат, где проявляет гибкость и какие задачи решает лучше всего. И конечно, когда речь зайдет о выборе инструмента, мы можем углубиться в знание этого инструмента и наконец задать вопрос, какие методы содержит класс Object и почему гораздо круче использовать три вложенных цикла и милкшейк, вместо Stream API.
Спасибо за ваше время, пожалуйста напишите почему я не прав и в чем разница между Spring и Spring Boot.
Комментарии (99)
muhaa
23.10.2021 22:54+4Предлагаю: Давайте возьмем реальную бизнес-задачу и попросим человека рассказать, как бы он работал над ней. Послушаем какие вопросы он задает, как работает его мышление.
В разных коллективах могут быть разные подходы (вплоть до совершенно кустарно-гнездовых) и опыт собеседующего тоже может быть ограничен. В итоге сложно будет отличить человека который не умеет (и не научится) работать от того кто прямо сейчас еще не умеет работать именно так как принято здесь.
VGoudkov
23.10.2021 22:58+31Ответ с другой стороны баррикад: Эм... видите ли какое дело... Тут время от времени люди приходят на собеседование на позицию 150+К и не могут рассказать, в чём таки разница между Array и Linked. И хрен с ним с внутренним устройством. Ладно. На проекте такое же придётся зачем-то писать с нуля в исчезающе малом количестве случаев. Не ведь могут рассказать, в чём разница с точки зрения использования! Я уж не говорю про способность на пальцах прикинуть потребление памяти и процессора для разных случаев.
На просьбу рассказать о том, как организовать передачу данных между двумя потоками (производитель и потребитель) - молчат, как будто пытаешься выпытать секрет философского камня! Есть и те, которые супер отвечают... только после каждого вопроса какой-то очень подозрительный стук клавиш в фоне и задержка с ответом несколько секунд. А потом мы не можем написать блин FizzBuzz, или удалить элементы из массива! - для последнего случая задача звучит так - напишите тело функции void deleteNonSCities(List<City> allCities) {}, которая удаляет из списка все города с названием, начинающимся на букву "C". getName естественно есть... Причём написать предлагаем на стороне соискателя в его IDE, для чего пересылаем Maven проект с юнит тестами, которые собственно и проверяют выполнение задач.
Так что тут дело такое - во первых, поговорить про устройство стандартных классов из библиотеки - это поставить всех соискателей в более-менее равные условия. Во вторых - фильтр, чтобы не тратить своё и соискателя время...
StavrGodinovih Автор
23.10.2021 23:45Наверное стоило упомянуть в статье, что теоритические навыки можно знать горазло лучше практических. И иногда человек может быть подготовлен по теории очень хорошо, а на практике, не сможет разбить задачу и понять, что от его нужно. И я не предлагаю пропускать какую либо часть интерьвю, а начинать разговор с тех тем, которые дадут представление о реальном прошлом опыте, а не о том, что человек выучил и зазубрил.
sshikov
24.10.2021 09:49+7Я не знаю, что там человек выучил и что зазубрил, но я столько раз в реальном коде видел, как используют List там, где нужен Map, что почему бы и не спросить на собеседовании? Тем более что знание коллекций ничего почти не говорит о способности человека писать код, а вот их незнание — еще как говорит. Главное не ограничиваться только коллекциями, а использовать технические задачи только как повод поговорить. В том числе — о декомпозиции задач и прочем.
> почему я не прав
Да я бы сказал, что по большей части вы правы — просто вы говорите о плохих собеседованиях, где все ограничивается знанием коллекций. А на самом деле это два разных подхода, которые в идеале лучше сочетать.
Ну и скажем так — вот если посмотреть со стороны кандидата, то меня множество раз спрашивали про коллекции тоже. И никогда я не вдавался в лишние подробности, а рассказывал только общие вещи, типа того, что вот эта коллекция упорядочена, а вот в этой объекты уникальны, и этого всегда хватало спрашивающим.
А разница между LinkedList и ArrayList — вот скажите, вам-то правда не очевидно, чем связанный список отличается от массива? Вы как думаете, отсутствие ответа на такой вопрос совсем ничего не говорит об уровне отвечающего?northzen
24.10.2021 14:37+2Разговор бы сильно упростился, если бы в нем возникли слова "ложноположительный" и "ложноотрицательный", а так же их вероятностях и весе.
Norgorn
24.10.2021 01:48+7Ох, вот в ведь правы, но отвечать на это всё по сотому разу - кошмар, даже уже воспринимается как неуважение. Я бы предложил сразу начинать с вопросов "посложнее", пытаться обсуждать интересные вещи. Если кандидат плывёт - снижать сложность, пытаться нащупать опору.
Ведь собеседование в обе стороны работает, мне как кандидату очень хочется узнать, как и о чем у вас в команде думают, как обсуждают проблемы, какие вообще вопросы считаются интересными. Очередной раз отвечать стандартную муть - не даёт новой информации, и из обратных вопросов её получить намного сложнее.
apro
23.10.2021 23:00+1Языки, фреймворки, библиотеки, базы данных и прочее - это всего лишь инструмент для решения проблемы, и он должен быть подобран под задачу, а не наоборот.
Сюда и самих программистов стоит включить. Люди, а точнее и их знания и умения тоже сами по себе часть вводных при решении задачи.
Если есть для решения задачи больше всего подходит язык X и библиотека Y для этого языка X, а ваша команда состоит из Java программистов (где Java != X), то чаше всего быстрее переизобрести пару велосипедов и вкорячить пару костылей но при этом использовать Java. Потому что хотя решение на Java условно займет месяц, а на языке X всего неделю, но само обучение языку X и способам работы с библиотекой Y может занять два месяца.
SpiderEkb
24.10.2021 10:40+2Если бы все было так просто...
Кроме времени разработки, есть ведь еще такие факторы как эффективность, масштабируемость, устойчивость и сопровождаемость.
Наверное, есть задачи, которые можно сделать под текущие требования заказчика, сдать, получить свои деньги, а дальше трава не расти.
Но ведь бывает и так, что продукт потом нужно сопровождать. И переделывать, когда (например) клиентская база выросла в полтора раза и текущее решение на Java != X начало тормозить и перестало справляться с нагрузкой. И придется все равно переделывать ее на X потому что X нагрузку держит лучше.
Так что иногда приходится заглядывать вперед при принятии решения.
lobotomic
01.11.2021 18:34Лучше всё-таки избежать преждевременной оптимизации и оптимизировать тогда, когда необходимость стала очевидной.
NeoCode
23.10.2021 23:14+23Собеседования нужны, но это должны быть именно собеседования, а не экзамены и не тест IQ. Собеседования — от слова «беседовать», т.е. просто непринужденное общение на технические темы. Например, рассказать о проектах, в которых принимал участие; рассказать о самом запоминающемся проекте, о самом необычном реализованном алгоритме и т.п.; обсудить достоинства и недостатки языков программирования, фреймворков, технологий, операционных систем; показать и рассказать про свой код в публичных репозиториях, посмотреть чей-то чужой код и обсудить его с будущими коллегами. Или даже прочитать и обсудить умную техническую статью на Хабре:)
farafonoff
23.10.2021 23:35+18Есть еще культурная проблема: индийцы научились рассказывать про проекты замечательно, но в большинстве не могут написать fizzbuzz.
Когда начинаешь спрашивать про проекты глубже, они прикидыаются, что не поняли вопроса. А мне же нужно в отчете о собеседовании написать, почему я его не беру. Вот и приходится спрашивать по списку, чтобы честно написать: кандидат не ответил на 9 вопросов из 10.
Рассказ про Array и Linked list выравнивает не только кандидатов, но и культуры.
beeruser
23.10.2021 23:53-17просто непринужденное общение на технические темы.
Человек пришёл, чтобы получать от вас бабки ежемесячно, а вы ему зубы заговариваете?Например, рассказать о проектах, в которых принимал участие; рассказать о самом запоминающемся проекте, о самом необычном реализованном алгоритме и т.п
А если человек не участвовал в проектах?обсудить достоинства и недостатки языков программирования, фреймворков, технологий, операционных систем;
Это собеседование на какую должность? От программиста требуется чтобы он писал код.
Мне например глубоко фиолетовы достоинства и недостатки каких-то языков.
Да они все 100% являются говном.unclejocker
24.10.2021 00:43+14Мне например глубоко фиолетовы достоинства и недостатки каких-то языков.
Да они все 100% являются говном.Если вы можете внятно и мотивированно рассказать, почему - это уже само по себе тема для разговора.
dreesh
24.10.2021 01:12Все очень просто! берем 2 ведра - одно с медом, а другое с говном. Зачерпываем ложкой из ведра.... теперь у нас 2 ведра с говном.
dopusteam
24.10.2021 07:46+2В этой аналогии ложкой берут программиста без технического собеседования?)
StavrGodinovih Автор
24.10.2021 09:49Где-то в статье говориться, о том, что нужно опускать техничискую часть?
dreesh
24.10.2021 18:23Это тоже вероятно) Но выше говорили про языки. Бывает пользуешся неким языком Х, чувствуеш себя вдохновленным и все в нем хорошо, но потом узнешь про вот такую ложку в центре ядра и все как в кокашку наступил.
ne_kote
24.10.2021 09:50+3Человек пришёл, чтобы получать от вас бабки ежемесячно, а вы ему зубы заговариваете?
Это всяко лучше, чем устраивать стресс-тест с вопросами а-ля "назовите различия между версией 1.x и 1.y такой-то технологии/языка". Собеседования, оставившие лично у меня положительные впечатления о конторе, начинались именно как беседа на сопряженные с работой темы, и заканчивались различными кейсами.
А если человек не участвовал в проектах?
Если у него нет ни рабочих, ни пет-проектов - добро пожаловать в стажёры. Часто это даже не уровень джуна, какие бы теоретические знания там ни были.
Мне например глубоко фиолетовы достоинства и недостатки каких-то языков.
Да они все 100% являются говном.
Только один где-то говнистее другого, и надо знать, что где стоит применять, чтобы проект не помер от 100 рпс на хайлоаде из-за одного условного мудака, которому фиолетово, и он решил запилить бэк на паскале.
korus
24.10.2021 00:02+2Обычно собеседующий (технический) хочет узнать не то, что соискатель знает, а наоборот - то, что он не знает.
Если ваши собеседования превратились в скучную рутину с непонятными вопросами, возможно стоит изменить уровень компаний или должность.
Про бизнес, архитектуру и способы решения обычно говорят на system design, а не на техничке.
JordanoBruno
24.10.2021 13:10+1Обычно собеседующий (технический) хочет узнать то, что он сам хорошо знает. А так как уровень обычно невысок и знания фрагментарны - то и получается, что собеседующий занимается чем угодно, но не оценкой тех. уровня кандидата.
pae174
24.10.2021 22:36+1Для ликвидации человеческого фактора есть экзаменационные сайты. Brainbench например. Сажаете кандидата за комп и пусть сдаёт экзамен. Технический собеседующий при этом не нужен и его личные тараканы на результат никак не влияют. А собеседуемый лишён возможности заменить знание теории какой-нибудь харизмой или чем-то там ещё. По результатам экзамена берём топ N человек и приглашаем на поговорить. Срабатывает до уровня мидла, но дальше не очень хорошо срабатывает.
gochaorg
24.10.2021 00:03+1На мой взгляд прав, и на мой субъективный взгляд - проблема в тех же приславутых Soft Skill
По мне Soft Skill - это шапочный термин и очень не точный, из которого растут больше кол-во проблем, ведь в той же школе/институте нет таких обязательных дисциплин как: Логика, Теория аргументации, Ораторское искусства и соответственно на собесах спрашивают, то что знают - а это Hard (алгоритмы, сети, etc...)
Конечно это не отменяет того факта, что кандидаты действительно могут и не уметь в hard и как-то надо отсеивать, да и само собеседование не дешевое удовольствие по времени и силам
Racheengel
24.10.2021 00:09+13У нас в компании реально нет собеседований с заданиями. Мы приглашаем товарища "на разговор", где рассказываем про себя, а человек про себя. Если он в теме и согласен у нас работать - тогда ещё один раунд с генеральным, после чего выдаём оффер с испытательным сроком. По сути, человек сразу начинает работать в коллективе как полноценный сотрудник и получает уже реальные задания базового для нас уровня, а дальше - как пойдет (как справляется). Если в итоге всё всех устроило, то оффер становится бессрочным.
Как показывает практика, именно испытательный срок это и есть лучший фильтр. И, кстати, по моему, был только один случай, когда человек его не прошел и ушёл спустя неделю. В остальных случаях срабатывало.
MyraJKee
24.10.2021 01:20+10Хороший подход. Мне он нравится. Именно так устроился на последнее место работы.
Одна проблема, легаси код ужасающий, понабрали просто кого попало.
wataru
25.10.2021 12:05+1Действительно, лучший способ проверить, как человек работает — это посадить его работать.
Но у испытательного срока есть свои проблемы — это на порядки дороже и сложнее для компании. Во многих случаех это просто физически не применимо. Если вы не прочь увеличить штат и у вас раз в полгода появляется кандидат, то это работает. Если у вас 10 желающих на одно место, а некторые еще и с релокацией из других городов или даже стран, то это не работает.
Racheengel
25.10.2021 17:27Да не, на самом деле не всё так плохо - обычно, товарищ или сам понимает, что "не туда зашёл" и больше не появляется, или сразу видно, что за пассажир - например, если особо много болтает и хвалится - то такой тип и до оффера не дойдёт.
На испытательном сроке - увольнение возможно в любое время (с предупреждением за две недели). На практике не приходилось, обычно люди сами понимали, что не тянут, и уходили тихо-мирно.
Что касается релокации - она полностью возмещается по успешному проходжению испытательного срока. Но, как бы, те, кто был релоцирован, они и испыталку прошли нормально.
wataru
25.10.2021 19:26+1обычно, товарищ или сам понимает, что "не туда зашёл" и больше не появляется, или сразу видно, что за пассажир — например, если особо много болтает и хвалится — то такой тип и до оффера не дойдёт.
Этак вы разговорчивых дейстивительно сильных специалистов отсеиваете же! Слишком субъективно к тому же. Что касается, сами понимают… вам никогда не попадались люди, с откровенно поддельными CV? Думаете, на что они надеятся? Это особенно касается больших компаний — считается, что там можно достаточно долго изображать бурную деятельность и получать 5-ти значные зарплаты, ничего не умея. Потом еще и строчкой в резюме можно повышать шансы устройства куда-то еще для просиживания штанов. Таких не много, но они есть.
Потом, а если хороших товарищей все-равно осталось 5, а место в штате одно? Нанять всех 5-рых на испытательный срок и они будут знать, что через пару месяцев 4-ех из них уволят? Как думаете они будут работать? Как хорошо это скейлиться?
И я бы на условие "возмещение релокации только после испытательного срока" ни за что не согласился. Вдруг у фирмы что-то плохо станет, первыми уволят тех, кого можно уволить без компенсации. С испытательного срока. Вдруг выяснится, что в команде менеджер — мудак, и работать там невозможно? Придется весь срок сидеть терпеть, притворятся, что все наравится.
Слишком много рисков для сотрудника. Вы так заранее отталкиваете больше людей, чем отталкивали бы"бесполезными" собеседованиями. Конечно, если нанимаете из других городов. Это, конечно, если вы нанимаете из других городов.
Перечисленные мной минусы очень сложно убрать, если они к вашей ситуации относятся. Если у вас маленький "конкурс" на место, нанимаете практически только местных, и фирма небольшая и не очень распиареная, то испытательный срок, действительно — идеальное решение для вас.
Racheengel
27.10.2021 17:28Этак вы разговорчивых дейстивительно сильных специалистов отсеиваете же! Слишком субъективно к тому же.
Ну тут важно, о чём товарищ глаголит. Если он про свой прошлый-текущий проект рассказывает, это одно, а если вещает про абстрактные паттерны в вакууме или длинную карьерную родословную - тут уже сразу понятно, что за
петушокпассажир.вам никогда не попадались люди, с откровенно поддельными CV? Думаете, на что они надеятся? Это особенно касается больших компаний — считается, что там можно достаточно долго изображать бурную деятельность и получать 5-ти значные зарплаты, ничего не умея.
Честно говоря, не попадались, да как бы в разработку такие и не пойдут, вот в маркетинг - то да... Тут ведь именно испытательный срок позволит выявить такого залётного в течении пары недель - потому что "каждый шаг на глазах коллектива".
У меня скорее обратная ситуация была на другой большой компании - люди приходили на работу, а ... работы по сути не было. Наш отдел сильно зависел от другого, который должен был нам инпут давать - ну, и сидел народ по 8 часов, кто там книжку читал, кто интернеты... а что делать...
Потом, а если хороших товарищей все-равно осталось 5, а место в штате одно? Нанять всех 5-рых на испытательный срок и они будут знать, что через пару месяцев 4-ех из них уволят?
Ну, у нас обратная проблема - место есть, а людей нужных - мало. Потому что спец.знания нужны, которые не у всех есть.
В общем, если бы пять хороших сразу пришли - наверное, всех бы и наняли :) Но беда в том, что таких мало...
Jacen11
24.10.2021 00:28+6Такие вопросы на собеседованиях дают представление о базовых знаниях человека
нет, такие вопросы помогают завязать разговор и понять что человек не случайно зашел. Мне рассказывали случай, пришел чувак и сказал, я ничего вообще не знаю, но вы возьмите меня, я учусь быстро и у меня двое детей с женой
Почему мы сосредотачиваемся сразу на разнице между LinkedList и ArrayList?
никто на этом не сосредотачивается, если знает ок, если нет смотрят на его рассуждения, на его поведение. Видел собес чувака, ему задавали простые вопросы, а он уставился в одну точку и какую то чушь малосвязную нес, я абсолютно не понимал его логику и рассуждения. Потом специально спросил коллег, поняли ли они о чем он говорил, и у них такое же впечатление было. Очевидно что человек не смог бы как раз в те вещи про которые вы говорите.
вопросы об ошибках и неточностях в бизнес-логике
ну какие нахрен вопросы о бизнес логике, когда человек не может вывезти простейшие рассуждения? А бизнес логику ему аналитик и прочие коллеги объяснят если он нормально умеет рассуждать
так и подмывает задать вопрос: «А вы-то сами имеете опыт работы с многопоточностью? Вы это спрашиваете, потому что на проекте приходится работать с этим?» Но ты молчишь
а я вот не молчал. Прямо так и спрашивал, иногда обсуждали формальность этого вопроса, иногда я говорил как и что в реальности используется. И это тоже вас определенно характеризует
Давайте возьмем реальную бизнес-задачу и попросим человека рассказать, как бы он работал над ней.
часто так и делают
Во всём этом ПРОЦЕССЕ знание языка и стандартной библиотеки, с которой он поставляется - далеко не на первом месте!
конечно, так и есть. У меня был собес на котором в определенный момент я поплыл, вопросы были правильные, а мои знания поверхностные и унылые, у меня даже самооценка упала. Но я не молчал, что то предлагал, мы обсуждали варианты, как лучше было бы сделать и тд. В итоге меня взяли.
ЗЫ такое ощущение что у вас маленький опыт собесов
lllamnyp
24.10.2021 10:22+3такое ощущение что у вас маленький опыт собесов
А ведь вы правы. Действительно, откуда столько статей с хейтом в адрес собеседований? Полагаю, большинство просто их не любит, не умеет проходить и, как итог, это неприятный процесс, который бьёт по самооценке. Я собеседования прохожу в том числе и для фана, для меня это как попытаться пройти очередного босса в игре и меня уже давно не смущают дурацкие вопросы, типа "чем отличается контейнер от виртуалки?".
Yoooriii
24.10.2021 02:07+9Собеседование говорите? Что спрашивать и как ставить вопросы. Тут такое. Случай из жизни: Взяли к себе в команду разраба, отличный программер, знал вот всё вот это что там выше говорилось + еще много чего, о чем далеко не каждый сеньор знает. Да и просто отличный парень (то есть с софт скилами тоже все ОК). Только вот одна беда: он приходил в офис и не работал. Мог на работу в день потратить часик, чтобы в Джире какую-то задачу как-бы закрыть, а остальное время пилил другой проект на стороне. Когда нужно было срочно пофиксить критическую багу (задержаться на работе на 1-2 часа), все как порядочные сидели, работали, а товарищ спокойно собрался и пошел домой: извините ребята, у меня семья, завтра доделаю, может быть. Причем формально, он все делал как-бы правильно, не подкопаешься.
То бишь о чём это я? Вы можете отсобеседовать и нанять супер профи, вот только никто не гарантирует, что он вообще принесет пользу вашему проекту.
Бывают и другие крайности. Вот вы мне на собеседовании задавали вопросы по паттернам и всяким модным фреймворкам? ОК, я тут вам сейчас такой код запилю, с 3-мя слоями абстракции + "оптимизированный" по самое немогу, что не каждый сеньор догадается как оно там работает.
Результат: через пол-годика чувак увольняется, а после него такая кака остается, что никто не знает, что с этим делать. И таки-да, код ревью он как-то проходил.
Как то так.
Xambey97
24.10.2021 11:37+1О, это отдельная порода людей, встречал таких. Не удивлюсь, если он одновременно работает на 4-5 работах также по 1-2 часа в день…
JordanoBruno
24.10.2021 13:14+2Такие парни действительно есть, но раз его не увольняют - то это проблема его непосредственного начальника, который не может организовать эффективную работу.
IsUnavailable
24.10.2021 21:17+15Все как порядочные сидели, работали
Может хватит уже бесплатную работу в ущерб интересам и жизни работника называть "порядочностью" и уж тем более возмущаться тем, что какие-то
лодырилюди не хотят отдавать время своей жизни сверх того о чём написано в договоре?Я понимаю негодование плохой работой данного конкретного человека, но нездоровая тенденция к переработкам, которая культивируется в том числе и нами, линейными работниками, уже поднадоела.
lexore
24.10.2021 03:01+6Автор спутал горизонтальное с вертикальным.
Посмотрите на это вот так: Вопросы про Array - это один уровень интервью. Вопросы про бизнес логику - это следующий уровень. Про бизнес логику можно спрашивать "после", но не "вместо". Потому что, если вы начнете их задавать "вместо", к вам сбежится куча народу с "общим пониманием", но без реального опыта.
И потом, где спрашивать про бизнес логику, как не на технических собесах? Есть HR собеседования, технические собеседования, собеседования на soft skills. Мне кажется, технические собеседования как раз и созданы для вопросов про бизнес логику :)
Ilusha
24.10.2021 05:27+1Ну что значит «без реального опыта»? У человека есть резюме, опыт работы, если по минимуму.
Я ещё пойму джуна собесить по главам справочника.
Но не мидла и выше. Здесь можно рассматривать практические комплексные кейсы. Да, их нужно будет заранее подобрать. Но, камон, если не уровень фаанг, то все эти вопросы «про Array» выглядят как неумение собеседовать.
Общение, короткое ТЗ и последующее его обсуждение дадут прекрасные результаты.
VGoudkov
24.10.2021 12:07+1Было. Собеседовали человека на middle+ и с опытом работы. Разобрали на словах один не самый простой пример "как бы я делал систему под такие use case". Вроде всё Ок, уже собрались брать - т.е. прямо по окончании собеседования сказать "готовьте документы и приезжайте оформляться" - это ещё до ковида было. Но на всякий случай решили попросить сделать тестовое задание (тут же на ноуте, одно из стандартной пачки). Для уровня кандидата - дел на пять минут, если знает Stream API и Collectors - вообще однострочник. Чисто посмотреть, как пользуется средой разработки и вообще, какой из подходов выберет. Завалился! А глядя на то, как он мучительно выбирал методы из того, что IDEA вываливает в выпадающем списке - у нас как-то сомнения закрались, а после выхода на работу он почитает ЧТЗ и также начнёт тупить?
JordanoBruno
24.10.2021 13:18+8Ваши сомнения на самом деле не имеют должного обоснования. Человек мог в минуту подзабыть все, что знал из-за стресса или банально не помнить что-то. Если человек технически грамотный и с правильным подходом - он решит эту задачу в спокойном рабочем порядке, сделав небольшой research. Умение найти решение проблемы гораздо важнее непосредственно знаний!
StavrGodinovih Автор
24.10.2021 09:58Горизонтальное с вертикальным можно спутать в том случае, когда эти вещи стандартизированы во всех компаниях. А это не так, компания компании - рознь. Где-то офер дают после первого технического собеса, а просы про задачи и понимание процессов опускают, а где-то ровным счетом наоборот. Оба варианты - плохие варианты.
dimoff66
24.10.2021 08:10+6Умение искать пути решения задачи это не техническое интервью, а тестовое задание. Некоторые считают(я правда не в их числе), что тестовые задания - зло. Но тестовые задания на собеседовании, будь то лив кодинг или декомпозиция задачи, стопроцентное зло, потому что собеседование, в том числе и тех интервью - как первое свидание, вы приглядываетесь друг к другу, атмосфера должны быть расслабленная и доверительная. Если вы хотите заставить человека напрягать мозг в условиях ограниченного времени это не способствует сближению. Я на обдумывание задач трачу 2-3 часа в спокойной обстановке, тогда я проявляю свой уровень и потенциал. Интервью не то место, где я могу это качественно делать, так как наивно полагать, что на интервью голова работает так же, как в обычном процессе, скорее она панически выплевывает первое пришедшее в нее решение. Такие задания на интервью это всегда проаерка на стрессоустойчивость, они не дадут ясной картины как человек способен думать в реальной рабочей обстановке, где если механизмы работы выстроены верно, всегда есть достаточно времени на обдумывание.
chernish2
24.10.2021 08:18Полностью согласен с автором. Из огромного числа собеседований, на которых я был в роли соискателя, лишь на одном задали очень простой и элегантный вопрос: как бы ты написал мп3-плеер?
А так приходится частенько задавать контрвопросы в стиле "а у вас действительно в работе эти нюансы используются, или вы просто для галочки спрашиваете?"
random1st
24.10.2021 08:46+3Почему не нужны-то? Нужны безусловно. Вот по формату возможны варианты. В последнее время в IT рассказывают только, как важны софт-скилы, а хард-скилы - плюнь да разотри, не нужны ни разу, научится на ходу. Извините, на работе все мы команда специалистов, а не сборище отличных ребят. Это не отменяет факта, что лучше когда и то и другое.
st__shadow
24.10.2021 10:29+4Такие статьи нужно начинать с представления себя. "Я, John Doe, собрал пять команд, каждая тянет проект с бюджетом ХХХ, и я хочу рассказать как делать интервью..."
Я вот тимлид, вырастил команду с 4 до 16 человек, проект высоконагруженный, 2млн запросов в час, 24/7.
Мы считаем, что базовые знания - коллекции, GC, основы мультипоточности - необходимое, но не достаточное условие, чтобы нанять хорошего инженера. На второй части - да, даём задание в контексте нашей предметной области. Можно пользоваться интернетом, IDE на свой выбор и всё такое. Некоторые теорию знают хорошо, а новый проект в своей IDE уже сделать не могут. С такими прощаемся.
JordanoBruno
24.10.2021 13:23+2Я вот тимлид, вырастил команду с 4 до 16 человек, проект высоконагруженный, 2млн запросов в час, 24/7.
Вы, конечно, извините, но это Ваше представление ровным счетом ни о чем не говорит. Нанять 12 человек - да проще простого. 2млн запросов в час - тоже не говорит ни о чем, каких запросов, куда? 24/7 - ну это вообще само собой подразумевается, в 2021-м году-то.
Надо представляться примерно так:
Собеседовал 500, нанял 100, сделали google.com и amazon.com, а в свободное время запускаем ракеты к Марсу.st__shadow
25.10.2021 20:58Ну, я ж про это и говорю - без контекста все советы ни о чем. Там ниже ещё пример привели, что такое высоконагруженное для них - 10к в секунду. Из тех, кого мы берём, они бы наверное одного из 10 взяли. А ко мне приходили кандидаты, для которых вся нагрузка - 3 запроса... в день.
Если вы собеседовали 500 и набрали 100, вот и расскажите, спрашивали про технические знания, или только тестовое, или как вообще набирали. Я бы послушал с интересом. У меня пока около 100 собеседований, наверное, с выхлопной 1 к 4 (я ещё другим командам помагал)
JordanoBruno
26.10.2021 12:16Я даже специально статью написал про тестовые задания ). С уровня Middle+ тестовое задание - это просто трата времени и ничего не говорит про уровень именно разработки, а не написания кода. У сеньора время непосредственно на написание кода уходит 20-30% в среднем, остальное это - сбор требований, планирование архитектуры, взаимодействие с другими членами команды и обсуждение подходов, поиск ошибок, дебаггинг.
Зачем я буду давать тестовое на 3 часа, если человек уже делал гораздо более сложные вещи, может показать какой-то код и обсудить его плюсы-минусы?
Я Вам в качестве примера могу привести Тинькофский NPM-модуль для работы с их API. При том, что сам код написан вполне неплохо и наверняка разработчик у Тинькофф считается сеньором минимум, он имеет массу недоработок, что говорит об отсутствии опыта у разработчика. Один из основных, базовых недостатков - разработчик забыл про таймауты. Или вообще не знал. А это базовые знания для разработки сетевого ПО вобщем и API SDK в частности. Поэтому я совсем не удивлен, что вся их платформа постоянно глючит и народ воет от багов.
Dimonana
24.10.2021 20:17Два миллиона запросов в час - это, извините, 600 в секунду,
Высоконагруженая, она же хайлоад, платформа, это хотя бы 10К запросов в секунды.
Так все что меньше, делается чуть ли не с закрытыми глазами.
JordanoBruno
25.10.2021 11:4110К запросов - тоже ни о чем. Мы же не знаем, сколько на бэке серверов обслуживает. Если их там 1000 - то это всего 10 запросов в секунду.
st__shadow
25.10.2021 21:02Если что, у нас есть открытая позиция, и даже про релокацию можно поговорить (Польша).
Да, вы правы, у каждого своё понятие высоконагруженности, и сильно зависит от контекста. Но приходили кандидаты, которые сеньёры, но с опытом пилил-проект-три-запроса-в-день-5-лет. Теория ещё кое-как, а вот на live coding всё плохо было.
Apathetic
24.10.2021 12:31Автор, расскажите, пожалуйста, о своем опыте. Сколько лет Вы в индустрии? Сколько собеседований прошли? Сколько собеседований провели? Сколько человек наняли? Хотя бы примерный порядок.
Ремарка о 98% в начале намекает на как минимум 50 пройденных собеседований, но что-то мне подсказывает, что это далеко не так.
JordanoBruno
24.10.2021 13:32+3Я лично провел не одну сотню собесов, могу сказать, что автор прав для уровня хороший Middle+. Какой смысл спрашивать джуниорские вопросы у сеньора про классы - меня это до сих пор удивляет. На 90% сеньор виден из резюме, подтверждается это обычно первыми 5 минутами разговора. Всегда надо помнить - человек берется для решения конкретных задач, а не как советник по документации Java.
Apathetic
26.10.2021 11:36На 90% сеньор виден из резюме
Не соглашусь. Посмотрел свою статистику: из 140 последних кандидатов с опытом работы 4 года и выше (из этой цифры вычтен нерелевантный опыт и сомнительный опыт типа фриланса) мы только 31 человека оценили на уровень senior и выше. Добавлю, что все эти кандидаты успешно прошли технический скрининг (15 супер-простых технических вопросов)
Я чот даже пригорюнился.
JordanoBruno
26.10.2021 11:55Уровень в разработке на самом деле мало кореллирует с количеством лет, отданных IT. И смотреть в резюме надо не на количество лет.
wataru
26.10.2021 12:09А на что смотреть? Объясните, как по резюме понять, что перед вами сеньер а не "сеньер"?
Apathetic
26.10.2021 12:09Сам собой напрашивается вопрос: а на что надо смотреть?
JordanoBruno
26.10.2021 12:39Каких либо четких признаков нет, но обычно у хороших сеньоров резюме по возрастающей и должности - только технические, образование можно не смотреть совсем, хотя профильные бауманка или ЛИТМО дадут небольшой плюс, конечно же.
Например - начал с уровня техподдержки, пока учился в универе, потом - пару лет джуниором в одном месте, потом пару лет миддлом в другом, потом сеньором. В описаниях, чем занимался - тоже по возрастающей сложности. Когда сеньорские должности уже - то там "Разработал с нуля". Есть опыт тимлидства - тоже плюсик. Работал в стартапах - еще плюсик.
Вообще резюме бывают и совсем необычно оформленные, но опытный глаз способен выцепить нужное, а в разговоре уже подтвердить или опровергнуть предположения.
surVrus
24.10.2021 13:23Языки, фреймворки, библиотеки, базы данных и прочее - это всего лишь инструмент для решения проблемы, и он должен быть подобран под задачу, а не наоборот.
Мне кажется не совсем все так просто. Задача всегда взаимосвязана с методами реализации. И обычно 99% задач среднего и низкого уровня - уже когда-то и кем-то были решены. И на их решения есть вполне неплохие best practice. Именно на уровне бизнес-логики, но часто и на уровне имплементации.
Поэтому часто просто требуется грамотно классифицировать задачу и привести ее к набору готовых типовых решений. У инженеров уже почти 100 лет есть такой принцип: "Не изобретай (новое) - комбинируй (готовое)". Часто требуется переформулировать задачу и объяснить Заказчику, что новая формулировка - и есть правильная постановка задачи.
Пример: задача учета сырья на складе. Сырье может называться по-разному (разные торговые марки), но это одно и то же химическое соединение. Причем могут быть разные партии, разные производители, разные доставщики... Задачу пытается сформулировать Директор, и тот, кто отвечает за учет на складе. Набор требований, спецификации и т. п. Решение же давно известно, все давно придумано и разработано в наборе стандартных процедур ISO/IEC 15288 и более обще - ISO 15704, в подходе ERP/MRP и даже полная имплементация в Ofbiz.
Изменяется сам подход к учету на складе, используется описанная в указанных стандартах логика. Заказчик сначала не понимает о чем речь, потом приходит в полный восторг, что "даже вот о таких мелочах подумали, все там продумано" - и соглашается, что так сделать лучше. В результате, решается совсем иная задача, но она дает именно тот результат, который хотел Директор. Причем плюс еще 100500 дополнительных "плюшек".
DumbJunior
24.10.2021 13:39Правильно уточнил, что речь о постсоветском пространстве. Тут как бы всё очевидно: с обеих сторон ушлые люди. Соискатели, не обладая элементарными знаниями, хотят устроиться на позицию 150+ тыр. Представители компании валят вопросами про многопоточность, докер и кафку и прочие кубернетесы, чтобы тупо завалить соискателя и предложить наиболее низкую зарплату ("ну вы же этого не знаете"). С обеих сторон идёт битва за бабло. Всякие там знания и скиллы -- дело десятое.
panzerfaust
24.10.2021 13:39+4Технические собесы, конечно, нужны. Хотя бы потому, что мы технари. Но их нужно уметь проводить.
Спрашивать по сотому разу разницу между реализациями листа - значит не уважать ни себя, ни кандидата, ни свое рабочее время. Это иногда напоминает протокольные разговоры о погоде в карикатурном представлении о высшем свете.
У тебя на проекте есть стек технологий и есть стек задач. И у кандидата был стек технологий и стек задач. До сих пор кажется, что не о чем поговорить, кроме линкед листа?
Допустим у тебя Kotlin + Spring + Postgres + Kafka. У кандидата Java + Camel + Oracle + ActiveMQ. Да здесь тупо по сравнительному анализу технологий и их применимости уже разговоров на час. Простой вопрос "в чем разница между kafka и activemq" может невероятно много рассказать о кандидате. Вот хотя бы читал ли он что-то о вашей кафке или надеется "приду - научат".
Но нет. Нам ведь лень читать резюме и вникать в персону кандидата. Лень придумывать вопросы, исходя из контекста. Давайте лучше на всякий случай про линкед лист уточним.
AlexunKo
24.10.2021 14:45На собеседовании нужно проверять отношение человека к сути своей работы. И наоборот - отношение работодателя к сути своей. Это взаимный реверс инжиниринг уровня ценностей/мотиваций.
DmitryOgn
24.10.2021 16:12+3>> Почему технические собеседования не нужны
Давайте отбирать по актерским данным (митинговая проактивность, правильные ответы на мотивационные и поведенческие вопросы, способность продать себя заказчику), как на Западе. Ну лягут потом роутеры по всему глобусу, так он все красиво объяснит, все будут довольны.
Dmitriy_Volkov
24.10.2021 17:31Ну не набирать же людей "за выслугу лет" или "каждому по потребностям" ????
По моим наблюдениям более менее соответствует позиции, на которую подаются, лишь каждый третий-пятый. Это не обязательно потому, что кто-то хочет обмануть или много хочет. Просто даже сам по себе диапазон уровней людей, которые именуют себя, например, мидлом, крайне широк. Аналогично ожидания разных компаний и разных проектов тоже сильно разнятся.
Соответственно, вероятность совпасть не так уж высока. Это к тому, нужно ли проверять.
Вопрос, как проверять. Обычно рассказываю о проекте, куда человек собеседуется, ключевые вещи, и прошу рассказать что у человека из опыта релевантно. По ходу рассказа могу задать пару уточняющих вопросов по технике дела. Например, если было многопоточное приложение, то спросить для чего были отдельные потоки, как они взаимодействовали, какие были проблемы. Если человек что-то разработал или хотя бы бакфиксил, это сразу видно. И даёт возможность понять что человек знает, может, насколько профессионально он подходит к работе. Это проверка именно на что человек может.
Обязательно прохожу по всем ключевым технологиям точечно, проверяя знания и понимание как использовать, как устроено. Поговорить по десятку-другому топиков нужно минут 15. Тут получаем понимание и о том, что человек не знает. Опять таки, неплохо спросить, а чем бы человек воспользовался вместо или как бы сам реализовал, если не знает, как устроено. Одно дело просто не использовал или не читал, а другое выяснить как понимает, как думает, как применяет незнакомые технологии.
Кодингом тоже не пренебрегаю. Даже минут 5-10 в условном режиме ХР тоже многое показывают.
В какой-то момент собеседование переключаю на английский
Также вразброс обычно нахожу время поговорить на отвлечённые темы, о текущей команде, процессах. Отвечаю на вопросы
В сумме около часа хватает. Это не так много по сравнению с месяцами, которые ты или твои сотрудники будут менторить, не дай Бог, без последующей отдачи.
kuftachev
25.10.2021 00:49+4Пусть у меня не очень большой опыт хождения по собеседованиям, могу сравнить Украину и Испанию.
Так вот, в Украине это было именно техническое собеседование, там спрашивали как инженера конкретные технические вопросы, некоторые подразумевали правильный и неправильный ответ, некоторые на показать мышление. Результат отбора - команда людей которые реально специалисты.
Испания - это разговор на отвлеченные темы, результат - просто набор случайных людей.
Я сам тут собеседовал людей, люди с 5+ годами опыта в Украине не прошли бы и на Джуна, во всяком случае те человек 7 которые через меня прошли. При чем, я спрашивал именно по тому стеку, который они заявляли, не по нашему, готовы были учить Гошечке за наш счёт.
Я не верю, что человек может эффективно решать задачи, если он не обладает знаниями инструментов с которыми работает. Не видит разных вариантов, их плюсы и минусы, на всех уровнях.
shybovycha
25.10.2021 03:41+2Я за годы собеседований узнал много чего. Но в широкой перспективе - все процессы найма - по сути русская рулетка: кто-то проходит все пять раундов, другой - достает свой сертифицированный кастом-шоп УЗИ и палит себе в голову.
Каждый интервьюер и каждая фирма имеют свои заморочки, равно как и кандидаты.
Собеседовали, было, барышню - СТО, куча наград, топ в каком-то списке (типа Форбс, но уже хрен вспомнишь) - красиво рассказывала про бизнес-достидения, а решить тривиальную программистическую задачу - не могла даже на словах.
Другой случай (целая каста случаев) - когда реально блин талантливых людей, решавших все задачи на отлично и суперски общавшихся резали (или опускали с мида до джуна) менеджеры, потому что человек не мог круто рассказать про бизнес-победы команды в проекте.
Некоторые фирмы (достаточно большие) предпочитают сжигать горы денег временем сотрудников (рекрутеров, менеджеров и разрабов) на интервью чтобы из 50 человек нанять ТОГО САМОГО. И это тоже с долей вероятности может оказаться провалом. Но потратить те же деньги на испытательный срок - жалко.
Золотой середины реально нету - все сводится к уровню проблем, на которых фирма и кандидат согласны балансировать аки акробаты, пока один не решит прервать этот цирк.
Vilaine
25.10.2021 08:32Собеседования нужны в частности для того, чтобы выбрать лучших кандидатов из имеющихся. Само собой, странно спрашивать в устном собеседовании какие-то детали кода, в индустрии разработки есть много более абстрактных тем (тестирование, взаимодействия, аббревиатурные принципы), о которых можно поговорить и которые выдадут как опыт разработчика, так и его проактивное стремление к улучшению этого мира.
no_future
25.10.2021 08:40+3Еще один взгляд с другой стороны баррикад. Конечно, каждый руководитель хочет работать с людьми умными, инициативными, нацеленными на результат. Но есть сроки, есть ограниченный бюджет на HR, поэтому на первое место выходит не «взять хорошего программиста», а «не взять плохого».
Что такое плохой программист? Это человек, не знающий отличия ArrayList от LinkedList. Или начинающий рассказывать, что такой простой вопрос его, великого, недостоин.StavrGodinovih Автор
25.10.2021 10:17Нельзя говорить, что плохого от хорошего отличает знание в разнице между LinkedList и ArrayList. Неужели вы никогда не забывали слов на собеседовании и при этом вы, казалось бы, не сильно волновались. Я понимаю, что разработчик должен вникать в основы и погружаться в глубь языка, но хорошего от плохого отличает его образ и паттерны мыслей в его голове. Неужели нанять перпективного программиста дороже, чем того, который знает "все" и перестал развиваться, хотя может и дешевле. Да, нет тут односложного ответа к сожалению:)
JordanoBruno
25.10.2021 11:43Что такое плохой программист? Это человек, не знающий отличия ArrayList от LinkedList.
Смешно. А если он погуглил за минуту и уже знает отличия, он за минуту стал хорошим?
no_future
25.10.2021 12:16Нет. Он за минуту стал не таким плохим, как минуту назад. Если же он загуглил, запомнил и понял весь теоретический минимум, и при этом умеет писать код — можно смело брать.
no_future
25.10.2021 11:39Нашел в интернете шикарнейшую статью о том, что такое хороший и плохой программист: github.com/daryllxd/lifelong-learning/blob/master/programming/philosophy/google-signs-youre-a-good-or-bad-programmer.md
Кто желает срубить кармы на ровном месте, может перевести и выложить.
GooG2e
25.10.2021 11:54У меня не такой большой опыт собеседований, поэтому всё нижусказанное это достаточно большое ИМХО.
Да это круто пообсуждать архитектуру или способы решения задачи, что будешь искать и т.д., но вроде в крупных компаниях для такого существует архитектурная секция, которая вполне себе может варьироваться в зависимости от уровня человека. Причём по каким-то базовым и банальным вопросам станет понятно, а насколько глубоко стоит лезть в эту самую архитектуру. Да и от внутреннего устройства компании всё сильно зависит - где-то тебе могут разложить всё на косточки и тебе даже задумываться толком не придётся, а где-то нужно продумать от и до всю архитектуру и как от вводных перейти к собственно к реализации. Так что здесь всё уникально и зависит от компании.
Следующая проблема в обсжудении архитектуры, на мой взгляд, заключается в том, что это большая нагрузка собственно для интервьювера - да бывают откровенно плохие решения, но ведь их не так много, а всё остальное это балансировка и тебе самому нужно прикидывать в голове тьму этих решений. Причём это совсем не рабочая, а абстрактная задача. И это хорошо, если у тебя одно такое интервью, а если их пять в день - честно мне было бы тяжело, да и скорее всего очень быстро сам себя бы загнал в решение, которое я считаю оптимальным и было бы очень тяжело доказать обратное т.е. интервьювер был бы необъективен по отношению к кандидату.
Ну и третье для завершения так сказать - встречаются как люди с синдромом самозванца, так и наоборот завышающие свои навыки. Их всё таки неплохо как-то отсеивать. Я не могу сказать как на это реагируют по ту сторону экрана, но я когда не знаю как что-то работает в языке, то честно так и говорю - не знаю, но могу предположить, что используется вот такой механизм или вот такой. У этих механизмов есть такие-то плюсы и минусы. Надеюсь это воспрнимается адекватно, потому что ну очень редко это прямо влияет на то как ты кодишь - любой этот вопрос гуглится за пару минут при необходимости.
Итог такой - нет серебрянной пули)
hungry_forester
25.10.2021 22:44На любом собеседовании человек, который с лету отвечает на все вопросы, обычно overqualified. И в "эту чудесную компанию" работать не пойдет.
Widoon
25.10.2021 22:44+1Я один из тех людей, которые плохо проходят интервью, но хорошо работают (ну типа). Вот могу завалиться на каком-то джуновском вопросе, но сделать тестовое задание или ответить на более сложный вопрос или банально могу что-то забыть, но знать как это загуглить за секунд 10 и при этом интервьюверы смотрят на меня как на мошенника, который врёт что у него 7+ лет стажа) И после нескольких последних интервью аж бомбит от таких интервью и хочется чисто выучить всё эти вопросы (которые далеки от реальных задач) чтобы утереть нос этим работникам КГБ))
beDenz
26.10.2021 14:52Вам нужно просто чаще ходить по собеседованиям. Это то же своеобразный скилл, который нужно прокачивать. И где то через 5/10/20 собеседований вы уже будете предугадывать какой вопрос сейчас зададут.
panzerfaust
26.10.2021 15:33+1Если что и нужно, то это это научиться с первых минут определять кадров, которые строят все интервью на бестолковой банальщине. И не тратить на них свое время.
beDenz
26.10.2021 17:20В случае если вы не заинтересованы в данной позиции то да. Но, в таком случае, вопрос: почему вы вообще согласились на разговор. В обратном случае, хотят построить интервью на "бестолковой банальщине" - их право, вам же проще.
JordanoBruno
26.10.2021 21:09Поддерживаю. Это весьма полезно по многим причинам. Иногда попадают весьма интересные собеседующие, которые и про стэк расскажут и про инфраструктуру свою, а всегда интересно, на чем в известных компаниях пишут/строят. Ну и конечно можно вполне получить интересные предложения, а там уже и к своему руководству с офером прийти, показать, попросить надбавку.
StavrGodinovih Автор
27.10.2021 10:27Как раз это мне и не нужно:)
Я люблю сравнение собеседований с первым свиданием, вы показываете себя, таким, какой вы есть, что-бы девушку не ждал сюрприз в будущем. Точно так же и с компанией, не нужно никого обманывать и предугадывать, ваш работодатель должен знать, кто вы и на что способны.
beDenz
27.10.2021 10:53Хочу заметить, что я не ничего про обман не писал. Не так давно, проработав долгое время на одном месте, я понял, что засиделся и пришло время, что то поменять. Открыл резюме, назначил собеседование. И сел в лужу: на элементарнейшие вопросы я мямлил, как школьник, не сделавший домашку. На следующих собеседования я был уже посмелее и уже через парочку сам болтал больше чем та сторона. Сейчас же меня не смутят ни сложные вопросы, ни лайв кодинг. Я, честно, не вижу здесь никакого обмана, а вы?
А вот ваша аналогия про первое свидание не корректна, так как очень субъективна: большинство парней и девушек на первом свидании притворяются, чтобы произвести впечатление.
buzzo
Реальные бизнес-задачи практически всегда сильно связаны с контекстом бизнес-процессов компании, которые практически невозможно транслировать за ограниченное время собеседования.
StavrGodinovih Автор
А какие бизнес-задачи не связаны с контекстом бизнес-процессов?:) Нужно включить воображение и любая бизнесс задача может превратиться в легко-трансируемую и легко-вмещающуюся во временными рамки интервью.
buzzo
Не уверен в том, что это легко. Возможно у нас разное понимание бизнес-задач. Было бы любопытно увидеть пример бизнес-задачи, контекст которой можно полностью сформулировать за пять минут.
Я, когда провожу собеседования (PHP), задаю обычно довольно древний вопрос о разнице между абстрактным классом и интерфейсом. С одной стороны для ответа на этот вопрос не требуется знание внутренностей PHP, с другой - это неплохая стартовая точка для начала разговора об архитектуре. Таким образом я выясняю несколько вещей сразу: насколько соискатель является действительно опытным разработчиком, насколько хорошо он может коммуницировать с другими (доносить свою точку зрения) и насколько мне будет комфортно с ним взаимодействовать.
StavrGodinovih Автор
Какое собеседование идет 5 минут?
На планированиие, где учавсует команда зачастую не могут полностью декомпозировать задачу.
Наверное вы не поняли мою мысль, не нужно полностью и правильно сформулировать\понять\разложить задачу, нужно увидеть, как мыслит кандидат, как он делает рутинную и ежедневную работу. А рутинная и ежедневная работа состоит не только из кодинга.
a1ebedew
Контекст бизнес-процессов действительно отличается в разных компаниях и может быть весьма запутанным. Тем не менее, имея достаточно развитое абстрактное мышление, можно очистить практическую задачу от лишнего контекста и превратить в задачку для собеседования.
Пример:
В разрабатываемой системе существуют проекты (projects), к проектам прикреплены люди (people), также в проектах существуют важные даты (milestones). Система должна присылать участникам проекта напоминания о наступлении очередной важной даты за n рабочих дней до её наступления (например 10). Система не должна присылать уведомления в выходные дни (weekend). Если 10 дней до важной даты приходится на выходной - нужно уведомить заранее, т.е. в пятницу.
Как вы спроектируете подобную фичу?
VGoudkov
Я ещё предлагаю подумать, как бы изменился язык и программы на нём, если бы одну из этих фич (интерфейсы или абстрактные классы) создатели выпилили. И что нужно добавить, чтобы не было мучительно больно: множественное наследование? делегаты? конструкцию X, которая решает такую вот типовую задачу Y?
awfun
Мне кажется, думать над выбором интерфейсов в бизнес коде приходится даже реже, чем выбирать между List и Set
JordanoBruno
Должен константировать, что знание ответа на этот вопрос никак не добавляет плюсов знаниям и умениям разработчика, а также его способности качественно выполнять задачи в срок. Фактически, Вы тратите драгоценное время собеседования на очень незначительные вещи.
enree
Практика показывает, что в 50% случаев спрашивающий только думает, что знает разницу между абстрактным классом и интерфейсом. В принципе, если обе стороны не очень деревянные, то может выйти занимательная дискуссия, но иногда все заканчивается на "ага, понятно" и пометкой в блокноте.
mcpro
Я знаю как минимум 3-ёх программистов PHP, которые ответят вам на этот вопрос, но в в работе она окажутся полными нулями. И знаю одного, который ответит вам на этот вопрос только после «Окей, гугл», но выхлоп за троих. Это то что нужно бизнесу, быстрое корректное решение задачи. Да, он может быть не таким изящным и супер-быстро работающим, но экономить на спичках часто дороже, чем эту экономию проигнорировать.
У меня был один программист, который писал очень красивый код, прям загляденье. Знал все, что только можно было знать о языке программирования. Но с поиском решений для бизнеса было все как-то туго, работу делал очень долго, всегда оправдывая свой подход правильностью кода и до мелочей продуманными алгоритмами (на самом деле не видел дальше своего носа). А взял я его именно потому, что он так хорошо знал ответы на подобные вопросы.
Если вы не наемный интервьюер, то вы не будете страдать фигней, а посмотрите на то, что человек реально сделал до того, как прийти к вам. На то, на сколько он в теме вашего бизнеса. И его знание тонкостей языка программирования уйдет не второй план.
SpiderEkb
Видимо, зависит от бизнеса. Бывает и совсем наоборот. Когда во главу угла ставится эффективность решения.
Вот из недавнего. Приходит письмо от сопровождения:
Т.е. когда-то ответную часть сервиса на нашей стороне написали именно как
Но прошло немного времени, нагрузка увеличилась и все начало выходить из под контроля - сервис потребляет слишком много ресурсов, работает медленно.
Когда стал смотреть - ужас ужасный. Несколько участков достаточно тяжелого оверкода, фуллскан одной таблицы... Пришлось переписывать все. Править там было бесполезно.
Ушел от оверкода, обошел фуллскан, добавил кешрование результатов предыдущих вызовов. В результат после внедрения от сопровождения получаем:
А можно было сразу сделать нормально. Если подойти вдумчиво...
И ситуация не единичная. Это не первый случай, когда приходится заниматься оптимизацией на скорую руку написанного кода, который начинает тормозить.
mcpro
К сожалению красивый код не оказался чем то особенным и по скорости. Выяснялась страшная правда о том, что написание запросов MySQL и тем более их последующая оптимизация это непостижимая наука для программистов.
Я бы очень удивлен этому. Мы уперлись в то, что программисты не умеют пользоваться Гуглом для решения своих проблем. Ну и как результат, вместо ведения их за руку, мы просто передали более сложные задачи тому самому, который не умел в красивый код, но понимал принципы работы.
a1ebedew
Простите, конечно, но тут явно прослеживается какой-то внутренний конфликт, который выходит за рамки обсуждаемого вопроса. Я не верю, что нельзя выцепить из рабочего времени пару раз по два часа, чтобы ваш супер-специалист передал сакральные знания оптимизации SQL.
mcpro
Он работает 24/7 можно сказать, некогда ему выцеплять 2 часа, и он не хочет заниматься образованием работников. Мы не можем его заставить, это не входит в его обязанности.
a1ebedew
Это определение "звезды" (или bus factor, если хотите). Дело не моё, но наличие такого сотрудника в компании - бомба замедленного действия)
mcpro
Да. И нас эта звезда устраивает. Проще уволить всех остальных, знающих разницу между выше обозначенными типами массивов (если бы это был Java). Потеряем невыполненными 1% низкоинтеллектуальных мелочей.
VAE
> задача может превратиться в легко-трансируемую .
НЕ понял.