Библиотека собеса по PHP | вопросы с собеседований
3.38K subscribers
140 photos
2 videos
68 links
Вопросы с собеседований по PHP и ответы на них.

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

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

Работать у нас: https://job.proglib.io/

Наши каналы: https://yangx.top/proglibrary/9197
加入频道
Что такое opcache? Как он работает?

OPcache (Optimized Cache) — это расширение для PHP, которое осуществляет кэширование скомпилированного байт-кода PHP для улучшения производительности выполнения скриптов.

OPcache работает в нескольких этапах:

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

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

OPcache также предоставляет дополнительные возможности для оптимизации производительности:

- Предзагрузка определяемых классов: OPcache может предзагрузить классы, определенные в скриптах, для ускорения их доступа и использования.

- Контроль за памятью: OPcache имеет механизм управления памятью, который позволяет наблюдать за использованием памяти скриптами и в случае необходимости автоматически очищать кэш.

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

🗓 22 августа в прямом эфире разберем как математика применяется в разных отраслях бизнеса. И какие математические навыки необходимы для успешной работы в каждой из них.

Приглашенный спикер: Павел Запольский – Senior Quantitative Researcher at Exness и Co-founder GrowLytics. Запустивший более 10 проектов по машинному обучению и анализу данных для ведущих компаний.

😮 На вебинаре узнаете:

🔵 Математика в бизнесе: Чем отличаются разные сферы друг от друга. Почему стоит понимать специфику сферы
🔵 ML и продуктовое IT: Чем различается математическая сложность от индустрии к индустрии. Какие к ним необходимы уровни подготовки
🔵 Баевская математика в GameDev. Баевская математика как альтернатива AB тестированию. Как математические методы применяются в разработке игр
🔵 Finance: Что такое количественные финансы и математическое моделирование. Обсудим текущие индустриальные тренды в отрасли
🔵 Backtest: Как знания математики делают ваши активы более надежными
🔵 На практике подробно разберем два математических кейса по GameDev и Backtest.

➡️ Зарегистрироваться: https://proglib.io/w/a0d5bad4
Please open Telegram to view this post
VIEW IN TELEGRAM
Сравните include vs required, include_once vs required_once.

Когда речь идет о подключении файлов в PHP, часто используются две пары ключевых слов: include и require, а также include_once и require_once. Давайте рассмотрим их основные различия и сравним их:

include vs require:

include: Используется для включения файла в скрипт. Если файл не найден, PHP выдаст предупреждение, но выполнение скрипта продолжится.

require: Используется для включения файла, и если файл не найден, PHP генерирует фатальную ошибку и останавливает выполнение скрипта.

Рекомендация: Если файл является критически важным для работы скрипта, используйте require, чтобы предотвратить выполнение скрипта в случае отсутствия файла. В противном случае, если вы хотите продолжить выполнение скрипта при отсутствии файла, используйте include.

include_once vs require_once:

include_once: Подключает файл только один раз. Если файл уже был включен ранее, он не будет включен снова.

require_once: Аналогично include_once, но для ключевого слова require. Гарантирует, что файл будет включен только один раз.

Рекомендация: Используйте *_once, если существует вероятность, что файл может быть включен несколько раз, чтобы избежать конфликтов и ошибок.
В чем разница между методами dd() и dump()?

В Laravel методы dd() и dump() используются для вывода отладочной информации, но между ними есть некоторые различия:

Метод dd() (Dump and Die):

dd() расшифровывается как «Dump and Die».
Он выводит отладочную информацию и сразу завершает выполнение скрипта. Это удобно, когда нужно быстро остановить выполнение программы и просмотреть значения переменных или других данных.
Пример использования:

$data = [1, 2, 3];
dd($data);
// Выведет содержимое переменной $data и остановит выполнение скрипта.


Метод dump():

dump() просто выводит отладочную информацию, но не останавливает выполнение скрипта. Это полезно, когда нужно просмотреть данные на разных этапах выполнения программы, не прерывая её работу.
Пример использования:

$data = [1, 2, 3];
dump($data);
// Выведет содержимое переменной $data, но скрипт продолжит выполнение.


Таким образом, основное отличие заключается в том, что dd() завершает выполнение программы, а dump() — нет.
Что означает утверждение о том, что СУБД поддерживает контроль ссылочной целостности связей?

Утверждение о том, что СУБД поддерживает контроль ссылочной целостности связей означает, что СУБД автоматически обеспечивает целостность данных, связанных между таблицами. Она регулирует и проверяет соответствие значений внешнего ключа (foreign key) со значениями первичного ключа (primary key) родительской таблицы.
Назовите различия между nginx и apache.

Nginx (Engine-X) и Apache HTTP Server — это два популярных веб-сервера с отличиями в архитектуре, производительности и способах обработки запросов. Вот несколько основных различий между ними:

Архитектура:

Nginx: Асинхронная и событийно-ориентированная архитектура. Обрабатывает множество соединений с низкими ресурсами.
Apache: Многозадачная и процесс-ориентированная архитектура. Создает процесс для каждого соединения.

Производительность:

Nginx: Обычно более эффективен при обработке статических файлов и большого количества одновременных соединений.
Apache: Хорошо подходит для обработки динамических контентов, но может быть менее эффективным при обработке статических файлов и большого числа одновременных запросов.

Потребление ресурсов:

Nginx: Требует меньше оперативной памяти и может эффективно обслуживать большое количество одновременных соединений с низкими ресурсами.
Apache: Из-за создания процессов для каждого соединения может потреблять больше оперативной памяти, особенно при большом количестве запросов.

Модели обработки запросов:

Nginx: Один рабочий процесс управляет несколькими соединениями. Обработка происходит асинхронно и событийно.
Apache: Каждый запрос обрабатывается отдельным процессом или потоком, созданным для этого запроса.

Конфигурация:

Nginx: Конфигурационные файлы имеют более лаконичный и читаемый синтаксис. Больше сосредоточен на статической конфигурации.
Apache: Имеет более гибкий и многословный синтаксис конфигурации, что может быть полезным для сложных настроек.

Модули:

Nginx: Модульная архитектура, но требует перезапуска для внесения изменений в модульную конфигурацию.
Apache: Поддерживает широкий выбор модулей, и большинство изменений в конфигурации модулей можно применить без перезапуска.

Расширяемость:

Nginx: Часто используется как прокси-сервер или обратный прокси, легко интегрируется с другими веб-серверами.
Apache: Широко используется для обработки динамических контентов, поддерживает множество языков программирования и фреймворков.
Зачем нужно кэширование? Какую проблему оно решает?

Зачем нужно кэширование:

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

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

Уменьшение задержек для конечных пользователей: Кэширование позволяет уменьшить время загрузки страниц для конечных пользователей, так как часть данных уже находится на клиентской стороне или близко к ней (например, в CDN — Content Delivery Network).

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

Проблемы, которые решает кэширование:

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

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

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

Оптимизация работы с внешними API: Если веб-приложение взаимодействует с внешними API, кэширование может снизить задержки, связанные с запросами к этим внешним сервисам, и повысить отказоустойчивость.
Что такое DRY, KISS, YAGNI?

DRY (Don't Repeat Yourself — Не повторяйся): Идея заключается в том, чтобы избегать дублирования кода. Если у вас есть повторяющийся код, его следует вынести в отдельную функцию, метод или класс, чтобы обеспечить более легкое обслуживание и избежать возможных ошибок при изменении.

KISS (Keep It Simple, Stupid — Делай это просто, глупец): Принцип заключается в том, чтобы создавать простые, понятные решения, избегая излишней сложности. Простой код легче поддерживать, изменять и отлаживать.

YAGNI (You Ain't Gonna Need It — Вам это не понадобится): Этот принцип предупреждает от добавления функциональности, которая не является текущим требованием. Не следует создавать код, который предназначен для использования в будущем, но который на данный момент не требуется. Фокус должен быть на текущих требованиях.

Эти практики являются основой для создания гибкого, устойчивого и легко поддерживаемого кода.
Как PHP может взаимодействовать с HTML?

PHP может взаимодействовать с HTML различными способами, так как это веб-язык программирования. Основные методы включают:

Внедрение PHP в HTML:
В PHP можно встраивать код прямо в HTML-документы, используя специальные теги

Формирование HTML из PHP:
PHP может генерировать HTML динамически, в зависимости от условий, данных из базы данных и других переменных.

Использование PHP в файлах-шаблонах:
PHP-файлы могут использоваться в качестве шаблонов, где HTML и PHP объединены для создания динамических страниц.

Использование PHP-фреймворков:
PHP-фреймворки, такие как Laravel или Symfony, предоставляют инструменты и шаблонизацию для более эффективной работы с HTML.
Как хранить координаты точки на карте в БД?

Рассмотрим несколько возможных подходов:

1. Хранение отдельных полей с широтой и долготой:
- Создайте две числовые колонки в таблице БД, например, «latitude» и «longitude», представляющие широту и долготу соответственно.
- Для каждой точки, сохраните ее координаты в эти поля.
- При поиске точек на карте, вы можете использовать операторы сравнения или функции, поддерживаемые БД, для поиска точек в определенном радиусе или в пределах определенной географической области.

2. Использование географических типов данных:
- Некоторые реляционные БД, такие как MySQL с расширением Spatial, PostgreSQL с расширением PostGIS или SQLite с поддержкой расширения SpatiaLite, предоставляют специальные типы данных для работы с географическими объектами.
- Создайте колонку с типом данных для хранения географической информации, например, тип «Point», который позволяет хранить точку с заданными координатами.
- Сохраняйте информацию о точках на карте в этой колонке.
- Используйте функции и операторы, поддерживаемые соответствующим расширением БД, для выполнения географических запросов, таких как поиск точек в определенном радиусе или внутри границ определенного полигона.
В чем разница между использованием модели и построителя запросов в Laravel?

В Laravel модель — это объектно-ориентированное представление таблицы базы данных, а построитель запросов — это способ построения SQL-запросов с использованием свободного интерфейса.

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

Вот пример использования модели для получения всех пользователей из таблицы users:
use App\Models\User;

$users = User::all();

В этом примере модель User представляет таблицу users, а метод all() извлекает все строки из таблицы.

Вы также можете использовать конструктор запросов с моделью для создания более сложных запросов. Например, чтобы получить всех активных пользователей, упорядоченных по имени, используя модель:
$users = User::where('status', 'active')
->orderBy('name', 'asc')
->get();

В этом примере методы where() и orderBy() являются частью интерфейса конструктора запросов, но вызываются они на экземпляре модели User.
Какие виды кеш-хранилищ знаете?

Существует несколько видов кеш-хранилищ:

1. Файловое кеш-хранилище (File-based cache): Использует файловую систему для хранения кеша. Данные кеша хранятся в файлах на диске и обычно используются, чтобы кешировать небольшие объемы данных, такие как отдельные HTML-страницы или фрагменты.

2. Memcached: Распределенная система кеширования, которая хранит данные в оперативной памяти (RAM). Он быстро доступен и эффективно обрабатывает большие объемы данных. Memcached может быть использован для кеширования запросов к базе данных, API-запросов и других операций для увеличения производительности.

3. Redis: Высокопроизводительная система управления базами данных, которая также может использоваться как кеш-хранилище. Redis поддерживает различные типы данных и предлагает расширенные функции, такие как публикация/подписка и сортированные множества. Это обычно используется для кеширования запросов к БД, хранения временных данных и ускорения работы приложений.

4. APCu: Расширение для PHP, которое предоставляет хранилище кеша в памяти на уровне оперативной памяти (RAM). Оно подходит для кеширования небольших объемов данных и часто используется для кеширования результатов вычислений, загружаемых файлов и других операций.

5. Zend OPCache: Расширение для PHP, которое выполняет опкод-кэширование для улучшения производительности. Оно кеширует скомпилированный байт-код PHP-файлов, чтобы избежать необходимости повторной компиляции каждый раз при выполнении скрипта. Про него мы недавно рассказывали

Отличие между ними заключается в различном способе хранения данных кеша, масштабируемости, скорости доступа и функциональности. Файловое кеш-хранилище хранит данные на диске, в то время как Memcached, Redis, APCu и Zend OPCache используют оперативную память для хранения данных. Memcached и Redis являются распределенными системами, позволяющими горизонтальное масштабирование, в то время как остальные кеш-хранилища ограничены доступом только к одному серверу. Каждый вид кеш-хранилища имеет свои сильные и слабые стороны, и выбор зависит от требований конкретного проекта и его бюджета.
Что такое денормализация? Для чего она нужна?

Денормализация — это процесс организации реляционной базы данных, при котором избегается нормализация для повышения эффективности чтения данных.

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

Денормализация может применяться, когда нужно улучшить производительность при получении данных из базы данных за счет уменьшения количества соединений таблиц, упрощения запросов и сокращения времени выполнения запросов. Однако, важно помнить, что денормализация может привести к повышению избыточности данных и усложнению поддержки базы данных.
В чем разница между «echo» и «print»?

В PHP разница между echo и print заключается в следующем:

1.Возвращаемое значение:

echo: Не возвращает значение. Может принимать несколько аргументов, разделенных запятыми, и выводит их.
print: Всегда возвращает 1, поэтому может использоваться в выражениях.

2.Аргументы:

echo: Может принимать несколько аргументов, и их использование разделяется запятыми.
print: Принимает только один аргумент. Если вы пытаетесь передать ему более одного аргумента или использовать запятые для разделения, это вызовет ошибку.

3.Использование:

echo: Чаще используется для вывода HTML-кода и других строковых данных.
print: Часто используется для вывода единственного значения или переменной, особенно в контексте, где требуется возвращаемое значение.
Объясните разницу между $message и $$message

$message — это обычная переменная, имеющая фиксированное имя и фиксированное значение, тогда как $$message — это ссылочная переменная, в которой хранятся данные о переменной. Значение $$message может динамически меняться по мере изменения значения переменной.
Что такое ACID?

ACID — это аббревиатура, обозначающая четыре основных характеристики транзакций в базах данных: атомарность (Atomicity), согласованность (Consistency), изолированность (Isolation) и долговечность (Durability).

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

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

3. Изолированность обеспечивает, что каждая транзакция выполняется в изолированной среде, рассматривающей ее как единственную выполняющуюся транзакцию. Это гарантирует, что результаты одной транзакции не будут видны другим транзакциям, пока они не будут успешно завершены.

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

ACID-свойства являются важными для обеспечения надежности и целостности данных в системе, особенно в контексте критически важных приложений, где требуется консистентность данных.
Как использовать объект запроса(request object) в Laravel?

Объект request предоставляет удобный способ доступа к входным данным запроса в Laravel. Вы можете получить доступ к объекту запроса в методе контроллера, добавив параметр типа Illuminate\Http\Request:

use Illuminate\Http\Request;

public function store(Request $request)
{
$name = $request->input('name');
$email = $request->input('email');
// ...
}


В этом примере метод store() контроллера UserController получает доступ к полям ввода имени и электронной почты из запроса с помощью метода input() объекта request.

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

$name = $request->name;
$email = $request->email;

Это эквивалентно использованию метода input().
Какие вы знаете функции для работы с массивами?

array() — Создает массив.
array_diff() — Сравнивает массивы и возвращает различия в значениях.
array_keys() — Возвращает все ключи массива.
array_reverse() — Разворачивает массив.
array_search() — Ищет значение и возвращает соответствующий ключ.
array_slice() — Возвращает определенные части массива.
array_sum() — Суммирует все значения массива.
count() — Количество элементов массива.
sort() — Для сортировки индексированных массивов в порядке возрастания

Продолжите список в комметариях👇👇👇