PHP Center
610 subscribers
11 photos
1 video
33 links
Прокачиваем знания в программировании
Download Telegram
Продолжим тему работы с ошибками

Один из подписчиков канала поделился ссылкой на хороший материал по использованию исключений:

https://github.com/codedokode/pasta/blob/master/php/exceptions.md

Автор статьи очень доступно объясняет как и зачем используется этот инструмент (с примерами). Рекомендую
Нас уже почти 500!

Сегодня я решил дать вам интересную задачку!

Она скопирована с популярного ресурса, там же приведено и решение, потому ссылку на решение отправлю через неделю.

—------------------—

«Скобки»

Условие
На входе есть строка, содержащая только скобки из набора {}()[]. Необходимо определить, является ли она сбалансированной или нет.

Под сбалансированной подразумевается строка, в которой выполняются три условия:

1) для каждой открывающей скобки есть соответствующая закрывающая;
2) соответствующая закрывающая скобка должна быть после открывающей;
3) между двумя соответствующими скобками нет других скобок без соответствий между этими скобками.

То есть [([]{[]})] — сбалансированная, а {[}], [{)] и ]{}[ — нет.
Давно здесь ничего не было...
За время молчания у меня появились интересные темы и материалы, планирую поделиться с вами!

Сегодня об индексах в MySQL.

Не раз приходилось сталкиваться с проблемами, вызванными неправильным использованием / отсутствием индекса.
Они могли существовать месяцами, а порой и дольше. Причина тому - недостаточная информированность разработчиков.

Предлагаю вашему вниманию неплохую статью:
https://ruhighload.com/%D0%98%D0%BD%D0%B4%D0%B5%D0%BA%D1%81%D1%8B+%D0%B2+mysql

Мне очень по душе подобного рода материалы, так как рассматриваются основные понятия и цели использования, не углубляясь в детали.

Также хотел бы добавить еще одну важную деталь. В статье написано:
"При каждом обновлении или добавлении данных в таблицу, происходит запись и обновление данных в индексе."

Перед добавлением индекса стоит задать себе вопрос: насколько часто происходят операции записи и чтения из таблицы?
Вполне возможно, что количество записей в вашем приложении будет существенно превышать количество выборок. В таком случае стоит задуматься об оптимальном решении.
Доброе утро, коллеги!
Наверное, многие из вас используют для разработки замечательный инструмент - PHPStorm.

В данный момент JetBrains предлагает лицензии на свои продукты со скидкой 50%! Предложение будет действовать ещё около 33 часов.
https://www.jetbrains.com/promo/friends/

P.S. Это не реклама и не реферальная ссылка. Только что купил сам и делюсь информацией с вами ;)
Доброе утро!
Сегодня в дайджесте на habrahabr нашел интересный тест по PHP: https://phptestquestions.com

Тест состоит из 10 вопросов (меняются при перезапуске) из разных категорий. Результаты и правильные ответы можно получить на почту, указав ее в конце теста.

P.S. Ссылка на PHP дайджест: https://habr.com/company/zfort/blog/423491/
Нашел отличный ресурс по шаблонам проектирования
https://refactoring.guru/ru/design-patterns/catalog
(также на сайте можно найти информацию по рефакторингу)

Отличительная особенность материалов в том, что авторы не привязываются к конкретному языку программирования, а делают ставку на детальное описание сути паттернов, иллюстрации, принципы реализации, схемы и примеры с псевдокодом.

После ознакомления Вы можете попробовать реализовать шаблоны на выбранном языке программирования. В случае, если это PHP, можете также обратиться к:
https://github.com/domnikl/DesignPatternsPHP - здесь есть готовые примеры.
Доброе утро

77 дней остается до ожидаемой даты релиза PHP 7.3. Не так уж много.

Может быть, вам уже попадалась на глаза публикация о нововведениях в версии 7.3 на хабре. Если нет, вот ссылка: https://habr.com/post/422507/

Но это ведь не очень интересно, да? ;)

Предлагаю вот такую статью:
https://www.tomasvotruba.cz/blog/2018/08/16/whats-new-in-php-73-in-30-seconds-in-diffs/

Здесь описаны возможности, которые, вероятно, будут полезны в ежедневной разработке.

Уверен, что немногим захочется заморачиваться и устанавливать версию 7.3, потому можно попробовать выполнить интересующий код на сайте: https://3v4l.org/ выбрав нужную версию.

p.s. https://kinsta.com/blog/php-7-3/ еще один материал (на английском языке).
Доброе утро

Сегодня поднимем тему оптимизации SQL запросов.
В первую очередь хочу заметить: оптимизация - это не то, что можно отложить на потом.
Запрос может работать прекрасно во время разработки, но преподнести неожиданный сюрприз в production.

Анализировать оптимальность составленного запроса нужно здесь и сейчас. Если вы используете MySQL, он поддерживает удобнейший инструмент - оператор EXPLAIN.

На хабре есть хорошая статья с примерами: https://habr.com/post/211022/

После того, как вы ознакомитесь с новой информацией, просто заглядывайте в код (или в debug panel фреймворка), копируйте запросы, добавляйте к ним EXPLAIN и находите потенциальные проблемы.

Warning: До версии 5.6.3 MySQL поддерживает EXPLAIN только для запросов SELECT. Для более новых версий: SELECT, DELETE, INSERT, REPLACE, UPDATE.

На сегодня все :)
"Чем отличается composer.lock от composer.json?"

Вы не поверите, но около половины собеседований PHP разрабочиков можно заканчивать после этого вопроса 😞

Почему все так плохо? По-моему, причиной тому тесная связь современных php фреймворков и composer. Как правило, разрабочик получается проект где "все готово" и не нужно заморачиваться. И только со временем сталкивается с проблемами вроде версионирования, конфликтов в composer.lock, неправильным использованием install, update и т.д.

Вот что хочу посоветовать:

1) Первым делом изучаем принципы семантического версионирования: https://semver.org

2) Читаем документацию по composer, от корки до корки:
https://getcomposer.org/doc/

3) Читаем полезные практические советы:
https://habr.com/company/mailru/blog/346488/

4) Для закрепления создаем свою "hello world" библиотеку. С нуля. Устанавливаем эту библиотеку в свой проект, тестируем. Простой пример можно глянуть здесь: https://php-up.com/lesson/7
Доброе утро, коллеги!

Сегодня хочу поделиться последней в этом году технической заметкой.

Многим из вас знакомы классические шаблоны проектирования "Банды четырех". (Если нет, обязательно посмотрите).

Но даже разобравшись в них, мне всегда было непросто вспомнить все названия по порядку либо по принадлежности к группе. Слова просто крутятся и крутятся в голове, по несколько раз хочется сказать одно и то же название, а про какие-то просто забываешь.

В какой-то момент мне пришла в голову идея составить из названий шаблонов предложения со смыслом, чтоб проще было запомнить. Это называется "мнемотехника".

В итоге у меня получилось 4 предложения, хоть и не самой полезной смысловой нагрузки. Попробуйте или составьте предложения по своему вкусу. Это действительно работает!

---

Порождающие (5)

Строитель(1) одиночка(2) фабричными методами(3) создает прототип(4) абстрактной фабрики(5).

---

Структурные (7)

Заместитель(1) шерифа декорирует(2) фасад(3) моста(4) легковесными(5) гирляндами, скомпонованными(6) в одно целое и подключенными через адаптер(7) в розетку.

---

Поведенческие (11)

Хранитель(1) парка открыл замок и посетители(2) смогли купить у посредника(3) билеты на карусель цепочка(4), который находился в плохом состоянии(5), но работал.

На каждой итерации(6) команда(7) меняла шаблонные методы(8) и стратегию(9), но наблюдатели(10) интерпретировали(11) это как поражение.
Доброе утро!

Не могу не озвучить приятную новость от GitHub.
Отныне бесплатным аккаунтам сервиса доступно безлимитное количество приватных репозиториев с участием до трех соавторов.

По-моему, это отличная возможность!
Сегодня (23 сентября) до конца дня еще можно бесплатно посмотреть видео и книги на Packt:
https://www.packtpub.com/free-learning
Доброе утро!

Мне часто задают вопрос: “Что нужно знать/изучить начинающему PHP разработчику?”
Думаю настало время на него ответить. В посте я буду перечислять навыки по некоторым субъективным уровням.

Шаг 1⃣
Минимальный набор. Изучаем: PHP, реляционная база данных, веб-сервер.

На этом уровне и так все достаточно понятно: самые базовые знания для того, чтоб делать простые сайты.

PHP: синтаксис, основы, типы данных, работа с базой данных (PDO), глубокое понимание реализации ООП в PHP (классы, объекты, свойства, методы, области видимости, интерфейсы, трейты), сессии, анонимные функции, работа с файлами.

Не критично важно, но уже на этом уровне вам будет очень помогать xdebug (инструмент для отладки кода). Да, с ним трудно подружиться (поначалу может быть трудно настроить и разобраться с принципом работы), но когда вы это сделаете, он не раз спасет в сложных ситуациях.

Веб-сервер. Сейчас наиболее популярными являются nginx и apache. Если вы только начинаете, я бы посоветовал обратить внимание на nginx. Необходимо понимание virtual hosts, умение настроить окружение для локальной разработки (можно при помощи google/инструкции).

На этом уровне очень важно “набить руку”. Достаточно часто ученики стараются как можно быстрее перейти на более сложные темы (например, берутся за фреймворки) и позже тратят большое количество времени на простые задачи, вроде обхода вложенного массива в цикле или экспорта данных в csv файл.

Базы данных. Конечно же речь идет о реляционных БД, в частности о MySQL (хотя это может быть и PostgreSQL и другие). Пусть вас не сбивают с толку популярные NoSQL решения и заголовки о том, что реляционные базы уже не модные/отошли в прошлое и т.д. Уверенно заявляю: до сих пор (в 2019 году) реляционные базы данные - основа для работы с данными в веб приложениях (и не только). Добавлю, что сейчас на рынке существуют очень хорошие NoSQL решения и они прекрасно решают поставленные перед ними задачи. Но это все немного позже.
SQL не должен вас пугать: умение писать основные запросы, делать выборки из нескольких таблиц с агрегациями, условиями, базовые понимания о индексах и типах данных, скорости выполнения запросов - это необходимый минимум на данном этапе.

Терпение! 😁 Решите 200+ задач (я не шучу) на циклы, условные операторы, работу с файлами, функциями, взаимодействием с БД. Это основа работы любого программиста.
Шаг 2⃣
Тачку на прокачку! Прокачиваем: паттерны, начинаем погружаться в SOLID, composer, frameworks.

Паттерны. Не стоит переоценивать эту тему. Равно как не стоит и забивать. Начните с шаблонов: Factory, Singleton, Builder, Adapter, Decorator, Facade, Strategy, Observer. Гарантирую, что вы увидите их во всех без исключения популярных фреймворках (в том или ином виде). Следует отметить, что перечисленные выше паттерны относятся к сборнику паттернов GOF (google). Есть и другие группы шаблонов: архитектурные, инфраструктурные, шаблоны проектирования для баз данных. На данном этапе не стоит лезть глубоко в дебри, но ознакомиться и понять области применения - must have.

SOLID - вообще отдельная история. Нельзя просто взять и осознать эти принципы за день. Да, можно выучить теорию и разобрать несколько примеров - именно так и нужно начать. Но со временем вы будете все глубже понимать идеи, которые несет в себе SOLID, а также мотивацию для его применения.

Composer. Я не зря написал его перед фреймворками. Часто так бывает, что программисты “получают” composer в тот момент, когда начинают знакомиться с фреймворком и это играет злую шутку. Если не освоить этот инструмент, в будущем потраченное время и проблемы гарантированы. Постарайтесь ответить на следующие вопросы:

- Что такое semver?
- Чем отличается composer.lock от composer.json?
- Зачем нужен packagist?
- Что значит опция --dev?
- Что такое PSR-4?

Если хотя бы на один вопрос вы затрудняетесь дать ответ, сделайте паузу, изучите тему глубже.

PHP фреймворки. Да, без них сейчас никуда. Абсолютное большинство серьезных разработок сейчас ведут с использованием opensource фреймворков. Какой выбрать? Исходя из состояния рынка на данный момент (октябрь 2019), для себя я бы выбирал из Laravel и Symfony. Могу сказать, что внимания заслуживает любой из TOP10. Дело вкуса.

Как изучать фреймворк? Мой личный рецепт - это 2 этапа:

- Читаем документации и cookbooks (бегло, не заморачиваемся на деталях). Основная цель - понять какой набор инструментов у нас в руках (без тонкостей их реализации).
- С целью получения практического опыта повторяем основной функционал какого-то популярного сайта. Например, BlaBlaCar, Instagram, Booking. Естественно, будет достаточно повторить 3-5 основных особенностей. Например, регистрация, создание/поиск/бронирование поездок/жилья и т.д.

Если вы последовательно двигаетесь в обучении, то на момент знакомства с фреймворком у вас в арсенале: отличное понимание OOP, вы знаете 5-10 самых популярных шаблонов, без проблем используете composer, умеете писать запросы к БД на чистом SQL. Эти знания помогут сфокусироваться на новых областях и не оглядываться назад на основы. Вот почему так важен последовательный подход.
Шаг 3⃣
Волк-одиночка - это плохо. Основы командной работы. Git, стандарты оформления кода.

Вы уже слышали о PSR-1, PSR-12? Да, я знаю, что к таким вещам лучше привыкать сразу. Но на практике вижу, что речь об оформлении кода заходит в основном тогда, когда код нужно кому-то показывать. В большинстве осмысленных проектов приняты некоторые стандарты оформления кода. Как правильно это PSR-1 и PSR-12 (PSR-2 - не так давно устарел).
На самом деле вам совсем не нужно знать наизусть все тонкости. Достаточно будет одного прочтения документации по стандартам. А соблюдать эти самые стандарты вам помогут специальные инструменты, например PHP_CodeSniffer и разнообразные плагины для PHPStorm.

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

Кстати, я надеюсь вы используете PHP Storm? Если нет, самое время переходить
Sublime, brackets, netbeans и другие IDE очень от него отстали и не очень хорошо подходят для профессиональной разработки.

Git. Как не странно, но до какого-то момента можно успешно работать и без системы контроля версий. Но, как только в проекте появляется > 1 разработчика, работа без git становится адом.
Напротив, если все члены команды хорошо владеют VCS, у вас никогда не возникнет головной боли от обновления версий кода или потерянных изменений.

Эти команды вы должны знать и уметь пользоваться в консоли: git branch, git fetch, git checkout, git pull, git push, git reset, git revert, git rebase, git merge, git stash и, возможно, некоторые другие.
Да, кто-то может обоснованно возразить: зачем, ведь есть IDE и встроенные функции?
Все верно, многие ими пользуются и это есть хорошо (я в том числе). Однако, есть два важных момента:

- Вы обязаны знать что именно происходит, когда вы нажимаете на кнопку “Rebase” или любую другую. Это поможет понимать суть происходящего и в случае необходимости решить проблемы в ручном режиме.
IDE есть не везде.
- Иногда вам нужно будет работать с удаленным сервером через терминал.

Конечно же, знать наизусть аргументы всех функций невозможно, да и не нужно. Однако, у вас должно быть точное понимание принципов работы основных git команд. Хороший идея - иметь под рукой собственный документ-шпаргалку.

Не обязательно, но может быть полезно посмотреть подход gitflow.

Иииии… Все на сегодня. Продолжение следует
Шаг 4⃣

Становимся немножко DevOps. Углубляемся в основы функционирования операционной системы, виртуализации.

Под операционной системой, конечно же, я имею в виду Linux. Вы не обязаны пользоваться Linux в качестве основной рабочей ОС. Но эта операционная система будет использоваться для ваших приложений: веб-сервера, базы данных и т.д.

Что нужно обязательно знать и уметь:

- Общее понятие о дистрибутивах Linux.
- Базовые навыки работы в терминале.
- Умение работать с пакетами (packages): установка, обновление, удаление.
- Пользователи системы (группы, права).
- Файловая система.
- Освоить на базовом уровне один из популярных консольных редакторов: (nano, vim, emacs,...): уметь открыть, создать, редактировать, сохранить файл. Лично мне больше всего по душе nano. Он очень простой, но его функций мне хватает ровно на 100%. Рекомендую.
- ssh, curl и как ими пользоваться.
- Научиться использовать планировщик заданий cron. Многие задачи в работающих проектах выполняются по расписанию (например, еженедельная отправка отчетов по почте), потому умение обращаться с планировщиком очень актуально.
- Писать простые bash скрипты.

Можно еще много чего написать, но это - основное.

После того, как вы подружитесь с Linux, можно браться за Docker. При условии, что вы более или менее освоили Linux, разобраться с Docker будет намного проще.

Необходимо:
- Знать что такое image, container, volume, network (в контексте Docker).
- Уметь написать собственные Dockerfile, build image, публиковать их на docker hub.
- Научиться работать с docker-compose.
- Понимать что такое host, port, socket, как контейнеры “общаются” между собой.

Как учить? Я бы рекомендовал по каждой теме (отдельно linux, отдельно Docker) найти источник информации (книга, видеокурс, блог) в котором будут затронуты перечисленные темы. Если глубины материала недостаточно, обращаться к другим источникам.

Помните: худшее, что вы можете для себя сделать - это учить наизусть все тонкости! Учить нужно принципы, а мелкие детали заносить в структурированную шпаргалку. Со временем шпаргалка станет не нужна.
5⃣ Вопросы - ответы

English - Да

Чем лучше вы знаете английский язык, тем более качественная и актуальная информация вам доступна. Не буду утверждать, что нельзя научиться программировать не зная английского - можно. Но чем более глубокими будут ваши знания по программированию, тем тяжелее будет находить переведенную информацию, порой и вовсе невозможно.

JavaScript (TS), frontend frameworks - Нет

Замечание: JavaScript (TS) - это очень хороший и интересный язык. Стоит ли с ним ознакомиться - однозначно. Это полезно и увлекательно. Но, если вы видите себя в роли backend разработчика, будьте им. Не нужно распыляться и тратить большое количество сил и времени на другие области.

HTML, CSS - Нет

Расскажу личную историю. В 2010 году, когда я только начал серьезно интересоваться web-разработкой, интернет был совершенно другим. Мне пришлось потратить многие месяцы на изучение HTML, CSS (их принципы, тонкости, свойства, хитрые трюки). И все для того, чтоб просто сверстать сайт. Через несколько лет все эти знания стали бесполезным мусором.
Повторюсь: если вы видите себя в роли backend разработчика, будьте им.

CMS - Нет

Можно ли зарабатывать деньги работая с CMS? Да!
Существуют ли среди CMS удачные решения актуальных проблем? Конечно!
Однако, по моему субъективному мнению, CMS - это не про инжиниринг. Большинство популярных систем управления контентом (WordPress, Joomla, 1С, …) - это какая-то альтернативная, не очень удачная с технической точки зрения ветка эволюции 😀

Что еще можно посмотреть, изучить?

Если у вас есть достаточный запас времени, посмотрите гарвардский Computer Science 50. Особенно полезным он будет в случае, если у вас нет профильного образования и вы хотите заполнить пробелы.

Good luck, have fun 🐘
Привет!
Практически каждый день я просматриваю резюме разработчиков и примерно раз в неделю провожу собеседования.
Появилась идея сделать большой пост о том, как писать резюме. Интересно? Голосуйте 👍👎

А пока, чтоб вы не скучали, новости из мира PHP 🐘
https://habr.com/p/472306/
Резюме Software Engineer 📄

В интернете вы найдете множество рекомендаций о том, как составить резюме. Большинство этих материалов написаны рекрутерами, менеджерами, копирайтерами, блогерами. Не готов судить хорошо это или плохо. Хочу лишь донести до инженеров точку зрения человека, который действительно оценивает CV и принимает решение о продолжении или прекращении процесса найма.

В этом посте вы узнаете:

- Какая информация должна быть в резюме
- Почему резюме на 1 страницу - булшит
- О чем говорить не нужно
- Что написать начинающим

Сначала я пройдусь по основным блокам и дам информацию. Порядок блоков важен.

1⃣ Общая информация:

- Имя, фамилия
- Город
- Email
- Номер телефона

Стоит ли добавить фотографию

Если есть приличная фотка, добавляйте. Если нет, ничего страшного.

2⃣ Цель / Позиция.

Четко определитесь и укажите позицию, на которую претендуете: trainee, senior software engineer, team lead и т.д.

Указывать ли зарплатные ожидания? Решать вам.
Вопрос достаточно личный, потому я предпочитаю оговаривать его позже.

3⃣ Summary

Напишите два-три предложения о себе.

Веб-разработчик с опытом работы 6 лет. Работал с микросервисной архитектурой и распределенными системами. Есть опыт работы в качестве team lead.

4⃣ Ключевые навыки.

Читать резюме будет инженер, но поиском занимается recruiter / researcher. Этот человек должен увидеть все сильные стороны кандидата в одном блоке и на первой странице.

Здесь нужно указать технологии, которыми вы владеете на уровне production. Т.е. использовали в работающем проекте. В идеале это список из 7-12 технологий, которые являются определяющими в вашей специализации. Конечно же, в вашем активе может быть больше технологий / инструментов / опыта. Но не нужно писать в key skills весь перечень, вы сможете их вписать в описание опыта работы.

5⃣ 🔥 Опыт работы.

Самый важный блок. Здесь вы должны перечислить несколько последних мест работы с релевантным опытом. Я приведу общий шаблон и также отвечу на основные вопросы.

👉 Информация о компании:

- Название
- Краткое описание - 1 предложение.

Например:

LLC Nasty Elephant
Nasty Elephant разрабатывает продукт для учета рабочего времени: “My Tracker”

👉 Позиция

Frontend Developer

👉 Даты и общий срок работы.

2018-01-01 - 2019-02-15 (1 год и 2 месяца)

Обязательно напишите в скобках сколько времени всего отработали.

👉 Обязанности

Чем вы занимались на данном месте работы. Минимум 3 пункта, лучше 5.

- Оптимизация работы базы данных для системы закупок.
- Поддержка и мониторинг существующих проектов компании.
- Миграция проекта с PHP 5.6 на PHP 7.3.
- Интеграция с платежными системами: PayPal, Stripe, ...
- Разработка телеграм-ботов.

Часто я слышу фразу: “Сказать особо нечего…”. Серьезно? В месяц вы пишите тысячи строка кода. Подумайте, вам есть что рассказать.

👉 Достижения 🔥

Ради этого пункта я затеял данный пост. Это сердце вашего резюме.

Чаще всего описание опыта работы сводится к “работал над …”, а информация о достижениях, к сожалению, отсутствует. А зря. Не стесняйтесь рассказать о своих достижениях (3-5 пунктов к каждому месту работы). Обязательно пишите правду. Например:

- Провел оптимизацию запросов и конфигурацию базы данных, что позволило ускорить работу API в среднем на 30%.
- Внедрил CircleCI для автоматического запуска Unit тестов, что позволило уменьшить количество ошибок на production.
- Предложил и успешно перенес приложение на ... фреймворк, за счет чего удалось значительно увеличить скорость разработки новых фич.

👉 Технологии

Здесь можете перечислить технологии с которыми пришлось работать на проекте. Этот пункт даст понимание работодателю об актуальности ваших знаний.

Вопросы к блоку “Опыт работы”

Что если мест работы очень много?

Выберите наиболее значимый и релевантный опыт.

Что если опыта нет вообще?

Это вообще тема для отдельного поста, но если в двух словах:
- Выберите один из популярных веб-сервисов (файлообменник, социальная сеть, туристический сайт) и попробуйте построить его упрощенную копию (очень упрощенную).
- Определите несколько (2-3) основных фичи.
- Реализуйте проект.
- Купите доменное имя и хостинг, задеплойте проект.
- Залейте код на github. Проведите самостоятельный code-review. Еще лучше - попросите посмотреть код кого-то более опытного в разработке. Внесите исправления в код по необходимости.
- Опишите что и как вам удалось сделать в этом тренировочном проекте, приложите ссылку на github.