Как стать программистом? Что нужно выучить? Ответ вроде прост: пойти в университет и там тебя научат. Но если вы спросите любого программиста он скажет что то чему там обучают, хоть иногда даже и бывает интересно, но почти бесполезно и совсем мало имеет общего с реальной работой.
Программирование — это что-то вроде грамоты
Наша профессия — одна из сложнейших, но самое забавное, что само программирование выучить довольно просто. Его даже спокойно изучают в школе. Чтобы написать простенькую программу в Паскале, школьнику достаточно знать штук десять операторов (а их всего пятнадцать) и несколько функций ввода/вывода, математических и работы со строками.
Эти операторы — как буквы алфавита, а функции ввода/вывода Read () и Write () — как первые слова, «мама» и «папа», с которых ребенок начинает постигать мир.
Тем не менее так же, как есть обычные люди, умеющие читать и изредка что-то пишущие, и есть профессиональные писатели, мастерски владеющие пером, сегодня есть пользователи компьютеров и есть программисты. И программистом, на мой взгляд, быть намного сложнее, чем писателем. У нас всегда сжатые сроки, нам приходится учитывать требования капризных пользователей и преодолевать ограниченные возможности медленных компьютеров, нужно сделать интерфейс максимально простым и удобным, хорошо все задокументировать, чтобы пользователи не терялись, и постараться все выполнить без ошибок, а еще заранее продумать, как программа будет развиваться в будущем, и сделать так, чтобы легко можно было добавить новую функциональность и чтобы она была понятной и предсказуемой. При этом саму программу нужно написать в одинаковом стиле, да так, чтобы другие программисты потом смогли после тебя разобраться и продолжить работу.
У писателей все намно-о-о-го проще. У них даже, наоборот, приветствуется, когда у автора — свой стиль, а сюжет — запутанный и непредсказуемый.
С программистами можно сравнить разве что создателей сериалов, которые тоже, по сути, пишут программу, только для актеров. Сценаристы, как и мы, работают командно, у них тоже есть сроки, релизы, им также нужно продумывать в голове хитросплетения сюжета и даже закладывать возможность в будущем сюжет поменять, добавить новых героев или воскресить прежних.
Но есть одно существенное отличие: сценаристы уже не могут переписать сюжет снятой серии. В лучшем случае, если зритель что-то недопонял, они прояснят это в следующей серии.
Нам же, программистам, приходится постоянно возвращаться к старому коду и что-то в нем менять. Представьте себе толстый роман, который вы писали десять лет, и вам приходится снова и снова переписывать каждую главу, превращая его в триллер. А теперь представьте, что вы перешли на другой проект и теперь должны сделать то же самое с текстом, который вы никогда ранее не видели, причем писали его несколько авторов, у каждого из них свой стиль и к тому же все они уже покинули проект.
Поэтому научиться программировать — относительно легко, но чтобы этим профессионально заниматься, нужно проделать титаническую работу. Писатели начинают с маленьких новелл, постепенно постигая все стилистические приемы, обогащают свою речь, сами много читают. Точно так же и программистам приходится много программировать и оттачивать свое мастерство. И черт возьми, это очень сложно! И постоянно — годами, десятилетиями — приходится совершенствоваться. Это долгий марафон, полный как терний, так и радости. Ни денежная, ни какая-то другая мотивация не помогут тебе — только твой собственный интерес к делу.
Я встречал ребят, которые заучили программирование, даже какие-то книжки из этой области прочли и принялись искать работу, но при этом не написали ни одной своей программы. Вы можете себе представить писателя, который, едва освоив грамоту и не написав ни одного рассказа, уже хочет устроиться в редакцию? Он вообще даже не знает, понравится ли ему это занятие и сможет ли он достигнуть успеха, но уже подсчитывает зарплату! Тем не менее, многие такие горе-программисты все же находят себе работу. Выполняют они ее скверно, но всегда существует круг таких задач, где высокое качество не так уж и важно.
Постепенно у программистов сложилась своя профессиональная лексика. Сам процесс написания программы они называют кодированием (Coding), а людей, которые кое-как освоили только это, уничижительно именуют кодерами. Они могут что-то вам написать, чтобы заработало, но потом улучшить, усовершенствовать такую программу будет крайне сложно и неприятно, обычно ее легче переписать. Сами кодеры называют себя разработчиками (Developers), а с течением времени, поднабравшись опыта, многие начинают именовать себя инженерами ПО (Software Engineer).
Оk, если программирование — это «как грамота», то что тогда еще нужно знать и уметь, чтобы стать «писателем»?
Постепенно из множества дисциплин, технологий и навыков выкристаллизовались общие и повторяющиеся, которые на практике оказались наиболее полезными для программистов.К сожалению, это все тоже непостоянно. Например, еще тридцать лет назад большинству программистов требовались знания по электронике, обработке сигналов и машинным кодам команд процессора (ассемблер).
Сегодня уже довольно успешно можно справляться с работой без этих знаний, и я даже был в шоке, когда однажды познакомился с Senior-разработчиком, весьма смутно понимающим, как работает процессор. Но зато за эти тридцать лет появился интернет, а программы стали огромными по размерам и очень сложными. И прибавилось множество других навыков и знаний, без которых сегодня ну прямо никак: гибкие процессы разработки, объектно-ориентированная и функциональная парадигмы программирования, построение масштабируемых высоконагруженных и отказоустойчивых систем, а еще необходимо уметь читать старый код и работать с ним, использовать системы управления версиями. Не обойтись и без такого обязательного навыка, как умение искать в интернете, которого раньше просто не было.
Все это выходит за рамки самого программирования и, по-хорошему, нуждается в каком-то своем, отдельном термине. Лично я для большей ясности называю «программерией» — это как Программная инженерия, но более широкий термин, охватывающий важное для нас: процессы разработки; умение программировать свой мозг, чтобы, например, «входить в поток»; умение работать в команде или составлять резюме — в общем, всё, чем мы занимаемся.
Основы программерии
Мне очень повезло, потому что я почти сразу же, как только увлекся программированием, прочел потрясающую книгу — «Совершенный Код». Она меня поразила тем, что это была не книга о каком-нибудь языке программирования или о технологии, как все то, что мне попадалось ранее, а книга о самом Программировании как таковом. Это, наверное, первая книга, которая попыталась заполнить пробелы, остающиеся после прочтения учебников по алгоритмам, технических руководств и документации.
И она сразу же начинается с метафор которые помогают точнее передать суть нашей работы. Вы уже узнали о Литературной метафоре, когда программирование сравнивается с писательством, но есть ещё популярная метафора сравнивающая программирование со строительством домов, или даже созданием самолётов.
Далее книга охватывает множество других аспектов и концепций: от рецептов написания высококачественного кода, тестирования и отладки до оптимизации кода и психологических факторов разработки.
Неслучайно она победила, в опросе «Если бы вы могли вернуться в прошлое, когда были еще начинающим девелопером, то какую книгу по программированию вы посоветовали бы себе прочитать?».
Затем появились другие хорошие книги о программерии:
- Ремесло программиста
- Программист-прагматик. Путь от подмастерья к мастеру
И множество других достойных, но в целом они охватывают глубже определённые области.
По сути, вся эта алхимия программирования на самом деле состоит из таких вещей с которыми мы работаем постоянно и нужно понимать:
- Основы компьютерной техники: основы Булевой алгебры, двоичная и шестнадцатирядная системы счисления.
- Устройство компьютера: процессор, оперативная память, стек, жесткий диск, графическая карта, шина, периферия (т. е. клавиатура, мышь).
- Ассемблер процессора и С — их тоже нужно знать хотя бы немного.
- Собственно базовая грамота: синтаксис, как объявлять переменную, функцию, как писать условный оператор if, приоритет операторов, как организовать цикл, как получить ввод от пользователя и как ему вывести. Структурное программирование — как писать без goto, используя циклы и рекурсию. Это легкотня на самом деле, пятнадцать операторов выучиваются быстро. Почти все используемые сегодня языки программирования наследуются от С (C++, Java, C#, PHP, JavaScript), так что переучивать их не придется. Поэтому, кстати, не особо важно, с какого из этих языков вы начнете обучение.
- Алгоритмизация: линейный поиск перебором, бинарный поиск, пузырьковая сортировка, быстрая сортировка и т. д. Оценка сложности алгоритмов.
- Структуры данных: строки, очередь, стек, одно- и двусвязный список, массивы и т. д.
- Декомпозиция, абстракция и проектирование программы: объектно-ориентированное программирование, SOLID, шаблоны проектирования, UML-диаграммы.
- Основы функционального программирования: как писать без деструктивного присваивания и циклов, работа с коллекциями в функциональном стиле.
- Знание платформы, библиотек, технологий: Java Core, работа с файлами, работа с Сетью, работа с массивами, строками и коллекциями, работа с памятью и сборка мусора. Обо всем этом есть толстые книги от самих создателей технологии (например, «Эффективная Java»).
- Стандарты и протоколы сети: TCP, UDP, HTTP, HTML, XML, JSON, MIME, RFC.
- Умение писать чистый код: как правильно называть переменные и классы, как форматировать код, как правильно писать комментарии (точнее, как их не писать:-)). Понимание приходит после прочтения книги Clean Code.
- Умение работать с кодом: рефакторинг (книга Фаулера), хоткеи IDE для рефакторинга, умение читать и сопровождать старый код.
- Инженерные практики: юнит-тесты, экстремальное программирование (XP), непрерывная интеграция, системы управления версиями (Git, SVN).
- Управление проектом и организация процесса: Waterfall, Agile, SCRUM, Kanban, баг-трекеры, оценка времени на задачу.
- Soft skills: умение общаться с заказчиком и ладить в команде, побороть отсутствие мотивации, выбрать приоритеты.
- Базы данных: SQL, реляционные, документо- и граф-ориентированные БД, ACID, теорема CAP, оптимизация запросов.
- Операционные системы: Linux, установка и настройка программ на нем, командная строка.
- Масштабирование и высокие нагрузки, мониторинг, логинг, отказоустойчивость.
- Криптография, защита от атак.
- Юзабилити, сбор требований.
- Знание английского языка, умение четко и лаконично писать документацию.
- Умение правильно формулировать вопросы и самостоятельно находить ответы на них.
- Умение учиться и при этом постоянно самосовершенствоваться.
- Умение обучать других, понятно объяснять и даже выступать перед публикой на конференциях…
- и при этом не слетать с катушек.
Как видите, этот список можно продолжать, но вы должны понять главное: именно само программирование — это совсем чуть-чуть. Почти все остальные навыки просто невозможно выучить. К ним можно только придти сквозь большой опыт и постоянное чтение правильных книг, которые помогут его переосмыслить.