(495) 925-0049, ITShop интернет-магазин 229-0436, Учебный Центр 925-0049
  Главная страница Карта сайта Контакты
Поиск
Вход
Регистрация
Рассылки сайта
 
 
 
 
 

Страсть к программированию. Глава "Научись рыбачить"

Источник: habrahabr

Лао Цзы сказал: "Дай человеку рыбу, и он будет сыт один день. Научи человека ловить рыбу, и он будет сыт всю жизнь". Это все хорошо и замечательно. Вот только Лао Цзы пропустил ту часть, в которой человек не хочет учиться рыбачить и завтра попросит у вас еще одну рыбу. Образовательный процесс требует наличия как учителя, так и ученика. Многие из нас слишком часто не хотят быть учениками. 

Не ждите, пока вам расскажут. Спрашивайте!

Но что является  рыбой  в программной индустрии? Это процесс использования инструмента, какой-либо грани технологии или специфической информации из вашей области бизнеса. Это знание, как сделать check out определенной ветки из системы контроля версий вашей команды, или умение поднять сервер приложений для разработки. Слишком многие из нас принимают подобные детали как должное.  "Кто-то другой может сделать это за меня" , - можете подумать вы. Парень, который собирает проект, разбирается в системе контроля версий. Вы просто попросите его помочь вам, когда потребуется. Команда, занимающаяся инфраструктурой, знает, как настроены файрволлы между вами и клиентами. Если вам что-то нужно поправить, вы просто шлете им письмо, и команда делает это. 

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

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

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

Чрезвычайно простой способ облениться - использовать кучу визардов, которые генерируют код за вас. Такой подход наиболее распространен в мире Windows-разработки, где, спасибо Microsoft, инструменты разработки делают многие задачи действительно простыми. Обратная сторона медали заключается в том, что многие Windows-разработчики не имеют понятия о том, как на самом деле работает их код. Работа визардов остается магией и загадкой. Не поймите меня неправильно - кодогенерация, при правильном использовании, может быть очень полезным инструментом. Например, генераторы кода, которые транслируют высокоуровневый C# в байткод, способый запускаться на .NET CLR. Вы однозначно не хотели бы писать весь этот байткод сами. Но, особенно на высоком уровне, позволяя визардам делать их работу вы оставляете собственные знания поверхостными и ограничиваете себя тем набором действий, который визарды способны выполнить для вас. 

Мы можем легко проглядеть рыбу в собственной предметной области. Работая в ипотечной компании вы можете попросить эксперта рассчитать для вас процентную ставку по каждому сценарию, необходимому во время тестов. Или вы можете научиться этому сами. Общение с вашими клиентами это хорошо, равно как и согласование с ними бизнес-требований (по сравнению с недопониманием и прикидыванием деталей на глаз самостоятельно). Но представьте, насколько быстрее вы могли бы развиваться, если бы вы действительно знали нюансы собственной предметной области. Возможно, вы не сможете узнать абсолютно каждое бизнес-правило - это не ваша работа. Но, как минимум, вы можете разобраться с основами. Многие из лучших работников IT-сферы с которыми я работал со временем становились лучшими экспертами в предметной области, чем некоторые из их бизнес-клиентов. Это приводит к повышению качества продуктов. Люди, не знающий предметной области, однозначно будут допускать глупые ошибки. Ошибки, которых можно было бы избежать, имея базовые знания предметной области. Более того, они будут менее эффективны (и в итоге обойдутся компании дороже) чем аналогичный разработчик, понимающий предметную область. 

Для нас, разработчиков ПО, высказывание Лао Цзы может быть перефразировано следующим образом: "Попроси рыбу, и будешь сыт один день. Попроси кого-нибудь научить тебя ловить рыбу, и будешь сыт всю жизнь". А еще лучше, не просите вас научить - идите и учитесь сами. 

Руководство к действию:

  1. Как и почему?  Сидя и читая эту книгу или будучи в следующий раз на работе, подумайте о гранях вашей работы, которые не понимаете до конца. Вы можете задать себе два невероятно полезных вопроса о любой области, которые помогут вам разобраться в ее сложностях:  "как это работает?"  и  "почему это происходит именно так?"
    Возможно, вы не сможете ответить на эти вопросы, но сам факт вопроса поможет уму войти в новое состояние и поспособствует лучшему осознанию вашего рабочего окружения.  Каким образом IIS-сервер передает запросы моим ASP.NET страницам? Почему я должен генерировать все эти интерфейсы и дескрипторы развертки для моего EJB-приложения? Чем отличается обработка компилятором статической линковки относительно динамической? Почему мы рассчитываем налог иначе, если наш покупатель живет в Монтане?
    Естественно, что ответ на любой из этих вопросов приведет к потенциальной возможности задать следующий вопрос. Если вы не можете спуститься дальше по дереву из вопросов  "как?"  и  "почему?" , вы, возможно, узнали достаточно.
  2. Немножко времени.  Выберите один из наиболее критичных и наименее известных вам инструментов из вашего повседневного набора и сфокусируйтесь на нем. Возможно это система контроля версий или библиотека, которую вы регулярно используете, но понимаете только поверхностно. Или редактор кода, который вы используете при программировании. Выбрав инструмент, отведите себе времени на ежедневное изучение  одной новой детали  о нем, которая поможет вам стать более продуктивным или позволит лучше контролировать ваше рабочее окружение. Вы можете, например, освоить GNU Bourne Again Shell (bash). В один из тех моментов, когда отвлекаетесь от работы, поищите в интернете  bash tips , вместо того, чтобы загрузить Slashdot. В течении минуты-другой вы должны найти  что-то  полезное, чего еще не знали о shell. А теперь, когда вы знаете новый трюк, можете начинать препарировать его вопросами  "как?"  и  "почему?" .

Ссылки по теме


 Распечатать »
 Правила публикации »
  Обсудить материал в конференции Дискуссии и обсуждения общего плана »
Написать редактору 
 Рекомендовать » Дата публикации: 23.12.2013 
 

Магазин программного обеспечения   WWW.ITSHOP.RU
ESET NOD32 Smart Security - лицензия на 1 год на 3ПК или продление на 20 месяцев, Ключ
Avira System Speedup, 1 ПК, 1 год
Nero Platinum 2018 VL 5 - 9 License corporate
YourKit Profiler for .NET - Floating License - 1 year of e-mail support and upgrades
Microsoft Visual Studio Professional w/MSDN AllLng License/Software Assurance Pack OLP 1 License No Level Qualified
 
Другие предложения...
 
Курсы обучения   WWW.ITSHOP.RU
 
Другие предложения...
 
Магазин сертификационных экзаменов   WWW.ITSHOP.RU
 
Другие предложения...
 
3D Принтеры | 3D Печать   WWW.ITSHOP.RU
 
Другие предложения...
 
Новости по теме
 
Рассылки Subscribe.ru
Информационные технологии: CASE, RAD, ERP, OLAP
СУБД Oracle "с нуля"
Новые материалы
Вопросы и ответы по MS SQL Server
Мастерская программиста
Программирование на Visual Basic/Visual Studio и ASP/ASP.NET
ЕRP-Форум. Творческие дискуссии о системах автоматизации
 
Статьи по теме
 
Новинки каталога Download
 
Исходники
 
Документация
 
Обсуждения в форумах
Ищу программиста PYTHON (1)
Ищу программиста для написание программ python 3 + библиотека tkinter Есть данные в БД...
 
Пишу программы на заказ профессионально (2265)
Пишу программы на заказ на языках Pascal (численные методы, списки, деревья, прерывания) под...
 
Ищу программиста для написания программы (17)
Ищу программиста ,владеющего Вижуал Бэйсик и программированием в Экселе, для написания...
 
Программы Delphi на заказ (236)
Пишу программы в среде Delphi на заказ http://bddelphi.ucoz.ru/
 
Пишу программы на заказ для студентов (186)
Пишу для студентов на с, с++, паскаль в средах ms visual studio, qt, builder, borland c, delphi....
 
 
 



    
rambler's top100 Rambler's Top100