Как стать хорошим программистом
2015.03.17
Зададимся вопросом: что нужно для того, чтобы стать хорошим программистом?
Как и везде, нужно развивать качества и навыки.
Для разработчика есть несколько навыков, которые, фактически, обязательны.
- Уметь читать и писать по-английски
- Уметь “вслепую” печатать на клавиатуре
- Уметь грамотно и связно выражаться
Со стороны качеств - нужно всегда осознавать, что каждый день придётся узнавать что-то новое, процесс обучения не останавливается никогда. Нужно также в целом любить читать.
Со своего опыта могу сказать, что только с такими качествами можно нормально ориентироваться в разработке ПО.
Есть несколько книг, которые реально полезны для начинающего разработчика, и все они переведены на русский.
И да, математика в общем не нужна.
Так как вопрос о том, как стать хорошим программистом, то я делаю допущение о том, что вопроса “какие именно программы разрабатывать” не стоит. Нужно осознавать, что в целом можно выделить четыре типа приложений, и гораздо проще будет “осесть” в каком-то одном, а не пытаться уметь на мастерском уровне делать всё (это, на мой взгляд, не достижимо).
- Веб-приложения, такие, как, например, этот блог.
- Приложения реального времени, такие, как, например, серьёзные симуляции виртуальной реальности (“компьютерные игры”), или Google Earth.
- Программное обеспечение контроллеров, встроенное в аппаратуру (“встроенное ПО”), например, ПО калькулятора, стиральной машины, бионического протеза, инсулиновой помпы.
- “Коробочное” ПО, традиционное, которое условно “устанавливается” на компьютер и позволяет решать какие-то задачи.
Это разделение лично моё, в разных источниках можно прочитать другие варианты. Суть в том, что разные программы выглядят, составляются, и обслуживаются по-разному. Можно ещё условно выделить мобильные приложения, которые суть нечто среднее между веб-приложениями и “коробочными”.
Я обещал книги. Вот они:
- “Чистый код”, Роберт Мартин
- “Совершенный код”, Стив Макконнелл
- “Программист-прагматик. Путь от подмастерья к мастеру”, Эндрю Хант et al.
- “Идеальный программист”, Роберт Мартин
- “Алгоритмы. Руководство по разработке”, Стивен Скиена
- “Человеческий фактор. Успешные проекты и команды”, Том ДеМарко et al.
Здесь перечислены книги, которые образуют фундамент знания разработчика любого ПО вообще. Они великолепны. Я вот “алгоритмы” ещё сам не дочитал, но это потому что она просто систематизирует то, что я уже на собственном опыте узнал из разных источников. После этих книг имеет смысл почитать хардкор:
- “Структура и Интерпретация Компьютерных Программ”, Харольд Абельсон et al.
- На русском нет: “Concepts, Techniques, and Models of Computer Programming”, Peter Van Roy
Есть ещё несколько книг такого же характера - углубляющих знания и описывающих хитрые неочевидные приёмы, но я их ещё не читал, поэтому рекомендовать не буду.
Ещё есть пять книг, описывающих приемы не разработки, а сопровождения программ.
- “Рефакторинг”, Мартин Фаулер et al.
- “Приемы объектно-ориентированного проектирования. Паттерны проектирования”, Эрих Гамма et al.
- “Шаблоны корпоративных приложений”, Мартин Фаулер et al.
- На русском нет: “Specification by Example”, Gojko Adzic
- “Непрерывное развертывание ПО”, Джез Хамбл
Весь этот свод из 13 книг - это Веды разработки ПО. Никто не скажет, как стать “хорошим программистом” лучше, чем они.
Есть, конечно же, второй способ, более лёгкий, но который нельзя пройти в одиночку. ;) Можно найти уже установившегося “хорошего программиста” и работать с ним в паре. Есть техника “парного программирования”, но я не об этом, там нужно, чтобы квалификация была одного уровня. Я о том, чтобы делать за него какую-нибудь вспомогательную работу, и параллельно учиться на его примере.
Помимо фундаментальных знаний, нужны навыки собственно программирования, решения задач составлением программ.
Для их развития я лично бы порекомендовал выбрать какой-то один язык программирования и начать на нём решать какие-нибудь задачи, для начала простенькие.
Например, вы решили стать разработчиком веб-приложений. Освойте платформу Ruby on Rails, пройдя последовательно вот это руководство: http://railstutorial.ru/chapters/4_0/beginning или платформу Node.js, начав отсюда: https://nodejs.org/documentation/tutorials/ (я предупреждал про английский язык), или платформу PHP, начав отсюда: http://php.net/manual/ru/ (я предупреждал про любовь к чтению). Это в целом равномощные платформы, разница только в синтаксисе и некоторых специфических возможностях, трудно реализуемых на смежных платформах.
Или вы решили писать встроенное ПО. Тогда стоит начать с проекта Arduino: http://www.arduino.cc/, правда придётся вложиться в “железо”.
Или вы решили писать “коробочное” ПО, тут у вас огромный выбор языков программирования, например, Haskell: https://www.haskell.org/ или Erlang: http://learnyousomeerlang.com/ или C#: https://msdn.microsoft.com/ru-ru/library/67ef8sbd.aspx или Common Lisp: http://www.gigamonkeys.com/book/
Кстати, для оценки “хорошести” программиста можно воспользоваться вот этой “матрицей компетентности программиста”: http://dev.by/pages/programming_matrix