Из всех практик экстремального программирования, наибольшее сопротивление встречает парное программирование. Некоторые любят его, а некоторые ненавидят.
Болтливый кодер
Как и все, некоторые программисты любят обсуждать стоящие перед ними проблемы. Они, как правило, обсуждаются за чашечкой чая, будь это логика, которая должна быть в модели, или она должна быть извлечена в отдельный вспомогательный класс.
Что вы думаете? Принадлежит ли это к этому домену или нет? Много ли выполняет этот класс?
Естественно, что такой тип программистов испытывает наслаждение от парного программирования и понимает его преимещества, потому что он чувствует, что его навыки в паре улучшаются и код становится лучше. Конечно, вы столкнетесь с огромным количеством разговоров, но такие программисты продолжают работать даже за обедом, обсуждая волнующие их темы.
Герой в наушниках
Другие же больше любят работать в одиночку, они предпочитают воткнуть наушники и погрузиться в свой отрешенный от офисной суеты мир. Они не задают вопросов и стараются войти в нирвану программирования 🙂 Они, как правило, не большие фанаты парного программирования. Они не будут жаловаться, если посадить с ними кого-то рядом, хоть это и будет их раздражать. Но если посадить с ними кого-то с меньшими навыками, то они воспримут это как возможность поупражняться и будут более открыты для общения. Они могут упорно набивать код, пока не начинают понимать, что за ними уже минут 30 наблюдает их партнер. В таком случае они передают эстафету с видом «ну пакажи на что ты способен». Вы можете воспринять это как покровительство, но со временем «герои» осознают, что и они могут получить плюсы, которые помогут им на их пути в нирвану.
Трололокодер
Для некоторых, каждое действие совершенное другим — повод подискутировать. Эти люди клянутся, что наслаждаются парным программированием, но только если они могут указывать на ошибки партнера в паре. Они могут быть разрушительны для команды и очень часто являются страхом для напарника. Время лечит, и со временем эти засранцы перестают так яро что-то доказывать и начинают понимать то, как другие люди воспринимают их.
Техники парного программирования:
«Пинг-понг» программирование
Один пишет неработающий тест, другой должен заставить его работать, затем они пишут другой неработающий тест и т.д.. Это наиболее известная техника в парном программировании. Она достаточно неплохо работает, воспринимается как игра, в которой ты пытаешься сломать или починить чужой код, пытаясь привнести как можно меньше своего кода в него.
Слияние пары и саморазвитие
Данная техника подразумевает обмен знаниями между более и менее квалифицированными программистами. Данная техника также характеризует «героя в наушниках». Некоторые люди не понимают преимуществ парного программмирования, но скажите им, что это для обмена опытом и они примут его. С течением времени они даже начнут наслаждаться им. Но, конечно, они всегда могут вернуться к своим наушникам =)
Удаленное парное программирование
Здесь может возникнуть множество проблем при становлении пары. Но если пара сработается, то не будет уже особой разницы, сидят они за одним столом или находятся на разных континентах. Сейчас существует огромное количество различных способов удаленного взаимодействия, так что всех их здесь описывать не имеет смысла.
Ротация пар
Иногда ротацию пар крайне сложно реализовать, потому что у нас быстро входит в привычку постоянно работать с тему же самыми людьми.
Основная цель данной техники для всех разработчиков — знать все наработки по всем задачам. Ротация пар крайне важна для поддержания команды в хорошей форме. Наибольшим преимуществом ротации пар является возможность быстрой подмены внутри пар, т.е. таким образом мы защищаем себя от возможных простоев по причине отсутствия одного из программистов внутри конкретной пары, поскольку все внутри команды знакомы с контекстом задачи. Я думаю, не стоит привязывать ротацию к каким-то определенным временным рамкам, поскольку никто не любит прерываться в середине выполняемой задачи.
искал кнопку лайк, не нашел…
вобщем понравилось.
спасибо за перевод
Под статьей есть небольшой тулбарчик с твитером, фейсбуком, базом…
Отношение к программистам как к подопытным кроликам
если так судить, то для большинства психологов мы все — лишь лабораторные крысы…
психологам это позволиьтельно
а руководители в данной ситуации мало чем отличаются от психологов…
Поэтому, наверное, я и люблю фриланс.
Руководители бывают разные, иногда бывают и такие которые оставаясь тонкими психологами при этом не занимаются классификацией/селекцией/ротацией и т.д. у них все получается как-то само-собой.
А как вы определяете, что они не занимаются "классификацией/селекцией", если они остаются тонкими психологами? =)
Я работал в нескольких местах на разных должностях, и я успел изучить своих начальников. Были и такие которые пытались как-то классифицировать всех, что-то постоянно менять и т.д. А были и такие, с которыми просто приятно было работать и работа шла очень хорошо. Но не могу не согласится, классификация в статье очень правильная, в одном из типов я узнал себя, очень точное описание 🙂
Ну тут можно несколько переформулировать Лао-Цзы и получить "Хороший руководитель тот, о котором программисты знают, лишь то, что он существует" =)