Библиотека собеса по PHP | вопросы с собеседований
3.16K subscribers
191 photos
6 videos
126 links
Вопросы с собеседований по PHP и ответы на них.

По рекламе: @proglib_adv

Учиться у нас: https://proglib.io/w/9f3affba

Для обратной связи: @proglibrary_feeedback_bot
Download Telegram
Влияет ли unset() на потребление памяти в PHP?

​В PHP функция unset() удаляет указанную переменную, разрывая связь между именем переменной и её данными. Однако это не гарантирует немедленного освобождения памяти, занятой этой переменной. PHP использует сборщик мусора, который освобождает память, когда это необходимо или когда завершается выполнение скрипта. ​
PHP

Присвоение переменной значения null также разрывает связь с её данными, но, в отличие от unset(), оставляет переменную в области видимости со значением null. Оба подхода сигнализируют сборщику мусора о возможности освобождения памяти, но фактическое время освобождения определяется внутренними механизмами PHP. ​

В большинстве случаев явное использование unset() или присвоение null не требуется, так как PHP автоматически управляет памятью. Однако в сценариях с длительно работающими скриптами или при обработке больших объемов данных явное освобождение памяти может быть полезным для предотвращения её исчерпания. ​

Важно отметить, что unset() удаляет только ссылку на данные. Если другие переменные ссылаются на те же данные, они останутся в памяти до тех пор, пока все ссылки не будут удалены. ​

Таким образом, хотя unset() может помочь в управлении памятью, его использование не всегда приводит к немедленному освобождению памяти. PHP полагается на сборщик мусора для эффективного управления ресурсами, и в большинстве случаев ручное вмешательство не требуется.
👍52
Что такое gap locks в MySQL?

Gap locks в MySQL — это блокировки, применяемые на диапазоне значений индексов таблицы, но не на конкретную запись. Они используются для решения проблем с возможными фантомными чтениями и уровнем изоляции транзакций.

Когда выполняется операция SELECT с условием по диапазону значений, MySQL устанавливает gap lock на промежуток (gap) между найденными итемами или между первым и последним итемами в результате выборки. Gap lock блокирует вставку или обновление других записей, которые попадают в этот промежуток, и предотвращает получение непоследовательных данных другими транзакциями.

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

Однако, стоит отметить, что использование gap locks может увеличить вероятность блокировки и снизить производительность в высоконагруженных средах. Поэтому, при разработке приложений на PHP с использованием MySQL, важно тщательно оценить необходимость использования gap locks и продумать стратегию обработки блокировок для обеспечения оптимальной производительности и надежности системы.
1
Что такое type hinting, как работает, зачем нужен?

Type hinting в PHP — это возможность указывать ожидаемые или допустимые типы данных для параметров функций и функций-обратного вызова (callback). Он используется для определения типов аргументов функций и возвращаемых значений.

Type hinting выполняется при помощи объявления типа данных перед именем параметра функции или функции-обратного вызова.

В данном случае мы указываем, что параметры $a и $b должны быть целочисленного типа (int), а функция должна возвращать тоже целочисленное значение. Если будет передан несоответствующий тип данных, то PHP выдаст ошибку.

Type hinting в PHP имеет следующие преимущества и цели:

1. Увеличение надежности и безопасности кода: Type hinting позволяет контролировать типы данных, которые принимаются и возвращаются функциями, что может помочь предотвратить ошибки типизации и некорректное использование функций.

2. Улучшение понимания кода: Type hinting делает код более читаемым и понятным, особенно при работе в команде. Видя ожидаемые типы данных в объявлениях функций, другие разработчики легко могут понять, какие данные ожидаются для правильного использования функции.

3. Интеграция со средами разработки: Многие среды разработки, такие как PhpStorm, могут использовать информацию о типах данных для предоставления подсказок и автодополнения, что упрощает разработку и ускоряет процесс написания кода.

Однако, следует отметить, что type hinting в PHP не является строгой типизацией. Если передать аргумент, не соответствующий указанному типу, PHP будет пытаться выполнить приведение типов, что может привести к непредсказуемому поведению программы.
3
Как использовать конструктор запросов(query builder) для выполнения сложных запросов в Laravel?

Laravel предоставляет конструктор запросов, который позволяет строить SQL-запросы более бегло и читабельно, чем при написании исходного SQL. Конструктор запросов предоставляет ряд методов для построения запросов, включая select, where, join и orderBy.

В этом примере мы используем конструктор запросов, чтобы выбрать имя и номер телефона всех пользователей старше 25 лет, упорядоченные по имени. Мы соединяем таблицу contacts с таблицей users с помощью метода join и фильтруем результаты с помощью метода where.

Затем мы используем метод orderBy для сортировки результатов, а метод get — для получения результатов в виде коллекции.
🤔1
Зачем нужно ключевое слово final?

Ключевое слово «final» в PHP используется для обозначения, что класс или метод не может быть изменен или унаследован в дочерних классах.

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

Если метод объявлен как final, то он не может быть переопределен (перезаписан) в дочерних классах.

Если свойство объявлено как final, то его значение уже не может быть изменено, и оно становится константой
С помощью какой технологии написаны файлы конфигурации маршрутизации Symfony?

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

Файлы конфигурации маршрутизации в Symfony написаны с использованием технологий YAML, XML и PHP. app/config/routing.yml — это файл конфигурации маршрутизации по умолчанию в Symfony.

В PHP 8 для настройки маршрутов используйте родные атрибуты, а в PHP 7 вместо них используйте аннотации, предоставляемые библиотекой Doctrine Annotations.
Чем характеризуется эффективность кэширования?

Эффективность кэширования в PHP, как и в других языках программирования, характеризуется рядом параметров и аспектов, которые определяют, насколько хорошо кэширование улучшает производительность и уменьшает нагрузку на сервер. Основные из них включают:

Скорость доступа:

Время извлечения данных из кэша. Чем быстрее кэш-система может вернуть данные, тем эффективнее она работает. Например, чтение данных из оперативной памяти (RAM) быстрее, чем чтение с диска.

Время записи данных в кэш. Быстрая запись также важна, чтобы не создавать дополнительные задержки.

Процент попаданий (cache hit ratio):

Cache Hit Rate: Процент запросов, которые нашли данные в кэше, по сравнению с общим количеством запросов. Высокий процент попаданий означает, что кэширование работает эффективно, поскольку большинство запросов обрабатываются быстро.
Cache Miss Rate: Процент запросов, которые не нашли данные в кэше, и система была вынуждена обращаться к первоисточнику данных (например, к базе данных).

Экономия ресурсов:

Уменьшение нагрузки на базу данных. Чем меньше запросов к базе данных, тем меньше ее загрузка и тем быстрее она может обслуживать другие запросы.
Уменьшение потребления CPU. Кэширование уменьшает количество операций, требующих интенсивных вычислений.

Объем кэша (cache size):

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

Сложность управления кэшем:

Легкость внедрения и использования кэширования в приложении.
Простота настройки и конфигурирования параметров кэша.
Наличие механизмов для автоматического обновления и очистки кэша.

Согласованность данных (cache consistency):

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

Обработка ошибок и отказоустойчивость:

Как кэш-система обрабатывает ошибки и сбои.
Наличие резервных механизмов на случай недоступности кэша.
1👍1
Сравнение значений переменных в РНР и подводные камни? Приведение типов. Что изменилось в PHP 8 в этом контексте?

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

1️⃣Неявное приведение типов: PHP может неявно приводить значения переменных к определенному типу при выполнении операций. Например, при сравнении числа и строки, PHP попытается привести строку к числу.

2️⃣Типизация сравнения: Оператор == выполняет нестрогое сравнение значений с приведением типов, в то время как оператор === выполняет строгое сравнение без приведения типов. Строгое сравнение учитывает и тип данных и значение.

3️⃣Знаки сравнения: При использовании операторов сравнения (<, <=, >, >=), PHP также может производить неявное приведение типов.

Изменения в PHP 8:

В PHP 8 был добавлен новый оператор match, который выполняет строгое сравнение без приведения типов. Это позволяет писать более четкий и предсказуемый код.
В чем разница между match и switch?

1. Тип сравнения

switch: использует нестрогое сравнение (==), что может привести к неожиданным результатам из-за приведения типов

match: использует строгое сравнение (===), учитывая как значение, так и тип

2. Возвращение значения

switch: не возвращает значение; используется для выполнения кода в блоках case.​

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

3. Обязательность обработки всех случаев

switch: если ни один case не совпадает, и default не указан, код после switch продолжается без ошибок.​

match: если ни одно условие не совпадает и default не указан, выбрасывается исключение UnhandledMatchError.​

4. Синтаксис и лаконичность

switch: требует использования break для предотвращения «проваливания» в следующий case.​

match: автоматически прекращает выполнение после первого совпадения; break не требуется.

Когда использовать match?

🔹 Когда необходимо строгое сравнение значений и типов.​

🔹 Когда требуется вернуть значение на основе условий.​

🔹 Для более лаконичного и читаемого кода.​

⚠️ Когда предпочтительнее использовать switch?

🔸 В версиях PHP до 8.0, где match недоступен.​

🔸 Когда требуется нестрогое сравнение или поддержка «проваливания» между case.​
1
В чем разница между Serializer и Normalizer в Symfony?

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

Сериализатор (Serializer)

Сериализатор отвечает за преобразование сложных структур данных (таких как объекты и массивы) в определённый формат (например, JSON, XML или CSV) и обратно. Компонент Serializer в Symfony предоставляет унифицированный способ выполнения этого процесса.

Основные задачи сериализатора:

Сериализация: Преобразование структур данных PHP (объекты, массивы) в строковой формат (JSON, XML и т.д.).
Десериализация: Преобразование строкового формата (JSON, XML и т.д.) обратно в структуры данных PHP.

Например, если у вас есть объект, и вы хотите получить его представление в формате JSON, вы будете использовать сериализатор.

Нормализатор (Normalizer)

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

Основные задачи нормализатора:

Нормализация: Преобразование объекта в нормализованный массив.
Денормализация: Преобразование нормализованного массива обратно в объект.

Нормализаторы фокусируются на разложении и восстановлении объектов и массивов без непосредственного взаимодействия с конечным форматом, таким как JSON или XML. Они обрабатывают промежуточный этап преобразования данных в ассоциативный массив, который сериализатор затем может преобразовать в требуемый формат.
🔥2
Что такое sensitive данные? Как хранятся в базе? Как отражаются в логах?

Sensitive данные (чувствительные данные) — это информация, которая является приватной, конфиденциальной или важной для безопасности организации или пользователя. К таким данным относятся, например, пароли, номера кредитных карт, персональные идентификационные номера и т.д.

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

Sensitive данные не должны непосредственно отражаться в логах. Вместо этого должна быть сохранена информация о том, что операция на sensitive данных была выполнена. Например, вместо того, чтобы сохранять сам пароль в логах, можно сохранить запись вроде «пользователь X изменил свой пароль». Это делается для предотвращения утечки конфиденциальной информации в случае несанкционированного доступа к логам.
1
Коротко расскажите об истории PHP. Что появлялось в каждой версии?

PHP 1.0 (1995): Ранняя версия PHP, созданная Расмусом Лердорфом. Она представляла собой набор скриптов для отслеживания посещений его онлайн-резюме.

PHP 2.0 (1996): Внедрение синтаксиса, похожего на Perl, и добавление поддержки для работы с базами данных.

PHP 3.0 (1998): Полная переработка языка. Добавление поддержки объектно-ориентированного программирования (ООП) и формальное определение языка.

PHP 4.0 (2000): Значительные улучшения производительности и добавление новых возможностей, таких как суперглобальные массивы ($_GET, $_POST) и поддержка для расширений.

PHP 5.0 (2004): Основной момент — введение поддержки ООП с использованием классов и объектов. Добавление механизма обработки ошибок Exception.

PHP 5.3 (2009): Введение пространств имен, замыкания (closures) и поддержка late static binding.

PHP 5.4 (2012): Включение трейтов (traits), короткого синтаксиса для массивов, и улучшения в производительности.

PHP 5.6 (2014): Поддержка переменных переменных, использование оператора ** в качестве оператора возврата.

PHP 7.0 (2015): Значительное увеличение производительности, введение строгой типизации (scalar type declarations и return type declarations), нулевой объединяющий оператор (null coalescing operator), и другие улучшения.

PHP 7.4 (2019): Добавление стрелочных функций (arrow functions), поддержка spread-оператора для массивов, а также улучшения в синтаксисе и производительности.

PHP 8.0 (2020): Множество новых возможностей, таких как JIT-компиляция для улучшения производительности, добавление строгой типизации для свойств классов, сопоставление шаблонов (match expression), и другие синтаксические улучшения.

PHP 8.1 (2021): Введение перечислений (Enums), readonly-свойств классов, асинхронной обработки через фиберы (Fibers), а также новые типы данных и улучшения производительности.

PHP 8.2 (2022): Добавление readonly-классов, поддержка дизъюнктивных нормальных форм (DNF) для типов, устаревание динамических свойств и новые типы в стандартной библиотеке.

PHP 8.3 (2023): Введение типизированных констант классов, атрибута #[\Override] для явного указания переопределения методов, глубокого клонирования readonly-свойств и новой функции json_validate().

PHP 8.4 (2024): Добавление деструктуризации массивов в цикле foreach, свойств-хуков (property hooks) для геттеров и сеттеров, упрощение синтаксиса анонимных классов и дальнейшие улучшения производительности.
👍71
Использует ли Laravel Symfony?

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

HTTP Foundation: Этот компонент используется для обработки HTTP-запросов и ответов.

Консоль (Console): Командный интерфейс Artisan в Laravel построен с использованием компонента консоли Symfony.

Диспетчер событий (Event Dispatcher): Система обработки событий в Laravel работает на основе компонента диспетчера событий Symfony.

Файловая система (Filesystem): Компонент файловой системы Symfony используется для операций с файлами.

Внедрение зависимостей (Dependency Injection): Laravel использует контейнер внедрения зависимостей Symfony для управления зависимостями.
🔥61
Cуперглобальные массивы.

Суперглобальные массивы в PHP — это предопределенные глобальные переменные, которые доступны из любой области видимости в скрипте. Некоторые из наиболее распространенных суперглобальных массивов в PHP:

1. $_GET: содержит переменные, переданные из строки запроса URL в качестве параметров. Они обычно используются для передачи данных через URL.

2. $_POST: содержит переменные, отправленные через HTTP POST-запросы. Этот массив обычно используется для передачи данных из формы на сервер.

3. $_SESSION: хранит переменные сессии пользователя. Эти данные могут быть доступны на протяжении всей сессии пользователя.

4. $_COOKIE: содержит переменные, переданные клиентом через HTTP-куки. Они обычно используются для сохранения долговременных данных о состоянии пользователя.

5. $_SERVER: содержит информацию о сервере и окружении, в котором выполняется текущий скрипт.

6. $_FILES: содержит информацию о файлах, загруженных на сервер через форму загрузки файлов.

Про остальные можно узнать в документации
1
Proglib ищет эксперта для ведения PHP-каналов. Нам нужен автор, который глубоко погружён в индустрию и пишет для опытных разработчиков.

🐘 ЗАДАЧИ:

➡️ Вести три канала о PHP: основной, задачи и собеседования.
➡️ Создавать контент Middle+: архитектура, оптимизация, разбор RFC, кейсы Laravel/Symfony.
➡️ Готовить задачи и вопросы для интервью с качественным разбором решений.
➡️ Работать с аналитикой: отслеживать метрики (охваты, ERR) и корректировать контент-план.
➡️ Мониторить комьюнити и оперативно упаковывать тренды в посты.

🎯 ТРЕБОВАНИЯ:

➡️ PHP Middle+: понимание работы движка, паттернов и экосистемы.
➡️ Стиль: умение писать для профи — ёмко, аргументированно и без воды.
➡️ Инструменты: уверенное владение нейросетями для ускорения работы.
➡️ Самостоятельность: вы сами находите темы и отвечаете за качество.

УСЛОВИЯ:

📍 Удалёнка, гибкий график, частичная занятость.
📍 Сдельная оплата за количество задач.
📍 Аудитория — тысячи профильных разработчиков.

👉 Оставляйте отклик, и мы свяжемся с вами!
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥4
Почему стоит избегать foreach ($array as &$value), если не требуется изменять массив?

​Использование конструкции foreach ($array as &$value) в PHP без необходимости изменения элементов массива может привести к неожиданным и труднообнаружимым ошибкам.​

⚠️ Почему стоит избегать foreach с ссылкой без необходимости

1. Сохранение ссылки после цикла
После завершения цикла переменная $value остаётся ссылкой на последний элемент массива. Если затем использовать эту переменную без её предварительного удаления, это может непреднамеренно изменить последний элемент массива. Это поведение может привести к труднообнаружимым ошибкам. ​

2. Повторное использование переменной в последующих циклах
Если переменная, использованная в качестве ссылки в одном цикле, повторно используется в следующем foreach без ссылки, это может привести к неожиданным изменениям данных. Это связано с тем, что переменная остаётся ссылкой на последний элемент массива из предыдущего цикла. ​

3. Непреднамеренные изменения при передаче массива в функции
Если массив передаётся в функцию после использования foreach с ссылкой, и внутри функции также используется foreach с ссылкой, это может привести к изменению оригинального массива, даже если он передан по значению. Это происходит потому, что переменная остаётся ссылкой, и при передаче массива в функцию изменения отражаются на оригинальном массиве. ​

Рекомендации

🔸 Используйте foreach ($array as $value) без ссылки, если не планируете изменять элементы массива.​

🔸 Если необходимо изменить элементы, предпочтительнее использовать foreach ($array as $key => $value) и присваивать новые значения через $array[$key] = ...;.​

🔸 После использования foreach с ссылкой всегда вызывайте unset($value); для удаления ссылки. ​

🔸 Избегайте повторного использования переменной, использованной в foreach с ссылкой, в последующих циклах без её предварительного удаления.​
👍4
Что подразумевается под понятием «триггер» в SQL?

Триггер в SQL — это предопределенный SQL-код, который автоматически выполняется (или «срабатывает») в ответ на определенные события в таблице или представлении базы данных. Триггеры могут быть использованы для автоматизации выполнения определенных действий при вставке, обновлении или удалении данных в таблице. Они предоставляют способ добавления бизнес-логики к базе данных.

Примеры событий, на которые могут реагировать триггеры:

AFTER INSERT (После вставки данных): Триггер срабатывает после вставки новой записи в таблицу.

AFTER UPDATE (После обновления данных): Триггер срабатывает после обновления существующей записи в таблице.

AFTER DELETE (После удаления данных): Триггер срабатывает после удаления записи из таблицы.

BEFORE INSERT (Перед вставкой данных): Триггер срабатывает перед вставкой новой записи в таблицу. Он может использоваться, чтобы модифицировать данные перед их вставкой.

BEFORE UPDATE (Перед обновлением данных): Триггер срабатывает перед обновлением существующей записи в таблице. Он может использоваться для проверки или модификации данных перед обновлением.

BEFORE DELETE (Перед удалением данных): Триггер срабатывает перед удалением записи из таблицы. Он может использоваться для проверки или сохранения данных перед удалением.
👍3
Как устроен Singleton и почему его считают антипатерном?

Синглтон (Singleton) — это порождающий паттерн проектирования, который обеспечивает, что у класса есть только один экземпляр, и предоставляет глобальную точку доступа к этому экземпляру.

Теперь рассмотрим, почему Синглтон часто считают антипаттерном:

1️⃣Глобальное состояние: Использование глобального объекта (в данном случае, единственного экземпляра класса) может привести к созданию глобального состояния, что затрудняет тестирование и усложняет понимание потока управления программы.

2️⃣Сложность в тестировании: Синглтоны могут вызывать проблемы при тестировании, так как они создают глобальные зависимости, которые не всегда легко подменить для модульного тестирования.

3️⃣Проблемы с наследованием: Наследование от Синглтона может стать проблемой, так как он имеет статическую точку доступа, которая не всегда вписывается в иерархию наследования.

4️⃣Сложность в масштабировании: Использование Синглтона может затруднить масштабирование системы, так как он создает глобальную точку зависимости, которая может стать узким местом.

5️⃣Проблемы с потокобезопасностью: Реализации Синглтона, как правило, не потокобезопасны по умолчанию, что может привести к проблемам в многопоточных приложениях.
2
Когда Symfony отказывает пользователю в доступе?

Когда неавторизованный пользователь пытается получить доступ к веб-приложению, Symfony отказывает ему в доступе. Он отображает страницу ошибки и возвращает HTTP-статус 403. Ошибка Access Denied, как следует из названия, на веб-странице означает, что веб-сервер отклонил ваш запрос на просмотр, либо потому, что веб-сервер работает неправильно, либо потому, что у вас нет правильных учетных данных.
1🤔1
Какие типы связей в базе данных?

Существует три типа связей между таблицами в базе данных:

«Один-к-одному» или 1:1. Это означает, что каждой записи в первой таблице соответствует не более одной записи во второй таблице, и наоборот.

«Один-ко-многим» или 1:M. Это означает, что одному экземпляру сущности может соответствовать любое количество (M) экземпляров другой сущности.

«Многие-ко-многим» или M:N. Это означает, что нескольким экземплярам одной сущности может соответствовать несколько экземпляров другой сущности.
🤔2
Почему json_encode([]) === '[]', но json_encode((object)[]) === '{}'?

​В PHP функция json_encode() преобразует структуры данных в строки JSON. Результат зависит от типа передаваемой структуры: массив или объект.​

🔍 Почему json_encode([]) возвращает '[]'
Пустой массив [] в PHP интерпретируется как последовательный массив без ключей. При преобразовании в JSON он становится пустым массивом: '[]'.​

🔍 Почему json_encode((object)[]) возвращает '{}'
При приведении пустого массива к объекту (object)[] получается экземпляр класса stdClass без свойств. При кодировании в JSON он становится пустым объектом: '{}'.​

⚠️ Важность различия
В JSON пустой массив '[]' и пустой объект '{}' — разные типы данных. Это различие может быть критичным при взаимодействии с API или клиентскими приложениями, ожидающими определённый тип данных.​

Как контролировать результат json_encode()

🔸Чтобы получить пустой объект в JSON, приведите массив к объекту: (object)[].​

🔸 Чтобы получить пустой массив, используйте [].​

Будьте осторожны с флагом JSON_FORCE_OBJECT, так как он преобразует все массивы в объекты, что может привести к нежелательным результатам.​
2