PHP (англ.PHP: Hypertext Preprocessor — «PHP: препроцессоргипертекста»; первоначально PHP/FI (Personal Home Page / Form Interpreter), а позже названный Personal Home Page Tools[9] — «Инструменты для создания персональных веб-страниц») — скриптовый язык[10] общего назначения, интенсивно применяемый для разработки веб-приложений. В настоящее время поддерживается подавляющим большинством хостинг-провайдеров и является одним из лидеров среди языков, применяющихся для создания динамических веб-сайтов[11].
В области веб-программирования, в частности, серверной части, PHP — один из популярных сценарных языков (наряду с JSP, Perl и языками, используемыми в ASP.NET).
Популярность в области построения веб-сайтов определяется наличием большого набора встроенных средств и дополнительных модулей для разработки веб-приложений[13]. Основные из них:
Автоматическое извлечение POST- и GET-параметров, а также переменных окружения веб-сервера в предопределённые массивы;
По состоянию на 2022 год используется сотнями тысяч разработчиков; согласно рейтингу корпорации TIOBE, базирующемуся на данных поисковых систем, в декабре 2022 года PHP находился на 10 месте по популярности среди языков программирования[11].
30 ноября 2017 (2017-11-30) — 30 ноября 2020 (2020-11-30).
$ PHP LTS до конца 2026.
Статус поддержки: анонсирована активная временная завершена $ опционально платная $ только платная
Каждая новая минорная ветвь разработки PHP (например, 8.4), разрабатывается в течение одного года и, как правило, в период с ноября по декабрь выходит очередной релиз первоначальной стабильной версии, которая бесплатно поддерживается в течение 4 лет. В течение 2 лет осуществляется активная поддержка ветви, обнаруженные ошибки и проблемы безопасности исправляются и выпускаются обновления в виде регулярных точечных релизов[23].
После окончания двухлетнего периода активной поддержки каждая ветвь получает временную поддержку в течение ещё 2 дополнительных лет только для критических обновлений, касающихся проблем безопасности. Релизы в течение этого периода выходят по мере необходимости: может быть несколько релизов или ни одного, в зависимости от количества отчётов об ошибках[24].
Начиная с версии PHP 8.1, по истечении 4 лет с релиза первоначальной стабильной версии, срок поддержки ветви завершается 31 декабря соответствующего года (наступает конец жизни ветви — End Of Life, также обозначается EOL) и она больше не поддерживается. В случае, если релиз первоначальной стабильной версии выйдет с задержкой (после нового года), то дополнительный год поддержки не предоставляется: например, релиз ветви PHP 8.4 был запланирован на ноябрь 2024 года, но даже если бы произошла задержка и дата релиза была бы перенесена на 2025 год, то срок бесплатной поддержки ветви все равно продлится только до 31 декабря 2028 года[25]. Использование устаревших версий PHP из неподдерживаемых ветвей не рекомендовано, потому что это может привести к уязвимостям в безопасности и ошибкам, которые были исправлены в более поздних версиях[26].
Zend предлагает платную активную долгосрочную поддержку — PHP Long Term Support (PHP LTS):
$ опционально платную для актуальных ветвей PHP;
$ только платную для устаревших ветвей PHP.
Срок платной поддержки каждой ветви начиная с релиза первоначальной стабильной версии составляет, как минимум, 5 лет[27][28].
Распределение версий PHP
Используемые версии PHP на 21.11.2024: день релиза PHP 8.4[29][30][31][32]
PHP 8.4 (менее 0,1 % от PHP 8) PHP 8.3 (9,40 % от PHP 8) — 3,56 % PHP 8.2 (26,6 % от PHP 8) — 10,08 % PHP 8.1 (38,6 % от PHP 8) — 14,63 % PHP 8.0 (25,4 % от PHP 8) — 9,63 % Совокупная доля PHP 8.x — 37,9 % PHP 7.4 (72,3 % от PHP 7) — 35,50 % PHP 7.3 (11,6 % от PHP 7) — 5,70 % PHP 7.2 (8,60 % от PHP 7) — 4,22 % PHP 7.1 (3,70 % от PHP 7) — 1,82 % PHP 7.0 (3,80 % от PHP 7) — 1,87 % Совокупная доля PHP 7.x — 49,1 % PHP 5.6 (54,4 % от PHP 5) — 7,0176 % PHP 5.5 (8,20 % от PHP 5) — 1,0578 % PHP 5.4 (15,3 % от PHP 5) — 2,9737 % PHP 5.3 (14,7 % от PHP 5) — 1.8963 % PHP 5.2 (6,80 % от PHP 5) — 0,8772 % PHP 5.1 (0,40 % от PHP 5) — 0,0516 % PHP 5.0 (менее 0,1 % от PHP 5)
Совокупная доля PHP 5.x — 12,9 % PHP 4.4 (75,9 % от PHP 4) — 0,0759 % PHP 4.3 (19,2 % от PHP 4) — 0,0192 % PHP 4.2 (3,70 % от PHP 4) — 0,0037 % PHP 4.1 (0,90 % от PHP 4) — 0.0009 % PHP 4.0 (0,40 % от PHP 4) — 0,0004 % Совокупная доля PHP 4.x — 0,1 %
W3Techs сообщает, что по состоянию на 21 ноября 2024 года (день релиза PHP 8.4) «PHP используется на 75,4% всех веб-сайтов, чей серверный язык программирования мы знаем».[33] Также сообщается, что из всех сайтов, использующих PHP:
PHP 8.x используют 37,9 % пользователей, из которых актуальные ветви с активной или временной бесплатной поддержкой (8.4, 8.3, 8.2 и 8.1) используют 28,27 % пользователей;
PHP 7.x используют 49,1 % — большинство пользователей:
PHP 5.x используют 12,9 % пользователей, версии, которые не поддерживаются исправлениями безопасности с 2018 года и, как известно, имеют серьёзные уязвимости.
PHP 4.x используют 0,1 % пользователей, версии, которые также не поддерживаются.
Это означает, что по состоянию на 21 ноября 2024 года подавляющее большинство сайтов — 71,7 %, использующих PHP, могут быть уязвимы для взлома; хотя в рамках PHP LTS от Zend ветви 8.0, 7.4, 7.3 и 7.2 (в совокупности 55 %) могут поддерживаться, кроме того некоторые дистрибутивы Linux, такие как Ubuntu и Debian, также предоставляют коммерческую поддержку и платные исправления безопасности, например, для ветви 7.4[34][35].
Устаревшие и неподдерживаемые ветви PHP, включая 7.1, 7.0, 5.x и 4.x (в совокупности 16,65 %) настоятельно не рекомендуются к использованию.
Дополнительные возможности
Язык автоматически поддерживает HTTP Cookies в соответствии со стандартами Netscape. Это позволяет проводить установку и чтение небольших сегментов данных на стороне клиента. Работа с Cookies организована посредством сеансов (сессий). У сессий есть срок действия (после его истечения данные удаляются), в сессиях можно хранить и редактировать разные типы данных, в том числе сериализованные — пропущенные через serialize (процесс происходит автоматически), PHP-объекты.
Создание GUI-приложений
PHP не ориентирован на создание десктопных приложений, но есть потребность в создании интерфейсов для настройки серверов, беспрерывного выполнения, отладки скриптов (сценариев), управления локальными и тестовыми серверами, и т. п. Из-за этого и возникли решения данной проблемы.
Расширения
Основное использование расширений — надстройки библиотек интерфейсов пользователя (UI-библиотек).
обёртки для использования интерфейса командной строки: PHP-UI, PHP-XCB.
Разработаны расширения, такие, как двусторонняя обёртка для использования других языков при написании расширений PHP, и наоборот. Например, PSV Component Library, — проект, состоящий из трёх подпроектов:
PHP4Delphi реализует соединения PHP с программами, написанными на Delphi средствами WinAPI; разрабатывался с 1999 года, но не обновлялся с 2009 года, из-за чего появились ответвления;
PHP extensions development framework — средство создания расширений PHP, VCL-компоненты — неотъемлемая часть PHP4Delphi, базовые компоненты которой нужны для создания приложений;
php4 Applications — расширение для использования PHP в других языках, базирующееся на PHP4Delphi, дающее доступ к макросам и упрощающее использование PHP, избавляя от создания обёртки.
Среды разработки (IDE)
Есть место и полноценным средам разработки для GUI PHP:
Dev PHP
Первопроходцем в этой категории является студия Dev PHP-IDE, которая использовала Kylix (Delphi) в качестве основы интерфейса и php-cli для создания пользовательских программ.
Она включала в себя редактор кода, несколько инструментов и визуальный просмотр HTML-страниц.
Впервые была представлена в 2002 году, сейчас имеет 3 стабильные версии, но разработка не продолжается — остановилась из-за гибели главного разработчика в автокатастрофе.
CodeGear Rad Studio (Расширение)
После DevPHP IDE появилось расширение — набор компонентов для CodeGear Rad Studio 2009 на базе php4delphi с некоторыми улучшениями (веб-элементы, инспектор, отладчик), поддержка её длилась в течение четырёх версий, вторая из которых вошла в платное расширение Rad Studio 2010: была возможность использовать скрипты, задавать стиль веб-компонентам, просматривать стили и веб-страницы до сборки программы, запускать локальный сервер, собирать программу, как отдельное приложение и отлаживать код. С выходом Delphi XE расширение получило название RADPHP Xe. Далее сама студия стала называться Embarcadero Delphi, и работа над данным расширением была приостановлена на неопределённый срок.
DevelStudio (RAD)
В 2009 году на базе php4delphi началась разработка среды для создания графических PHP-приложений, к разработке которой позже присоединился Ростислав Романов. Среда получила название PHP DevelStudio, первой опубликованной версией стала 0.1.7. DevelStudio имела небольшое количество компонентов в наборе инструментов и работала на устаревшем PHP 4. Во второй версии DevelStudio получила поддержку PHP 5. Были добавлены потоки, произведены множественные изменения и улучшения. Код сборки программ стал закрытым, предыдущие версии программы и сообщения на форуме были удалены с целью воспрепятствования злоумышленникам.
Вторая версия DevelStudio так же получила набор компонентов AlphaControls, вследствие чего её стали использовать для создания вредоносных программ в силу её простоты и понятности. Популярные на то время антивирусы (MacAffee, AVG, Avira) стали распознавать любые скомпилированные в DevelStudio программы как вирусы.
Через некоторое время автор AlphaControls обратился с жалобой к разработчикам DevelStudio, и набор компонентов был полностью удалён из среды, однако сохранился в уже существовавшей версии, удалить которую с форума в этот раз не представлялось возможным.
На момент 2012 года вышла последняя версия среды — 3.0.2, где появился новый набор компонентов, в том числе браузер Chromium вместо IE, что привлекло внимание веб-разработчиков и пользователей среды «Алгоритм». На тот момент компиляция программ в «Алгоритме» была платной, поэтому DevelStudio как новая и бесплатная среда разработки переманила на себя бо́льшую часть аудитории.
В 2014 году начались первые попытки по восстановлению среды, в этот раз со стороны сообщества. В конце 2018 года исходный код был восстановлен и доступен в GitHub.
В 2019 году сообщество обратилось к создателю DevelStudio с целью изменения политики распространения среды, вследствие чего она стала доступной для обновления и редактирования. Из-за жалоб на отсутствие ссылок на использованные библиотеки (DCEF, PHP4Delphi, TSizeCtrl, SynEdit) форум был удалён, а одна из страниц с описанием среды была перенаправлена на главную страницу сайта. С этого момента DevelStudio официально принадлежит сообществу.
DevelNext (DN)
Параллельно с этим главный разработчик DevelStudio начал создавать «реинкарнацию» предыдущей среды. Он взял за основу графическую библиотеку JavaFX, в результате вышла полностью новая среда, с поддержкой CSS, но без полной поддержки библиотеки Zend PHP — проект был основан на собственном языке jPHP. Его особенностью является, работа на JVM, JIT-компилятор, поддержка юникода, многопоточность и объектно-ориентированная стандартная библиотека.
В 16-й версии среда DevelNext получила поддержку php 7, а параллельно с этим jPHP был расширен энтузиастом для разработки под ОС Android.
На данный момент автор и энтузиасты трудятся над 2020 версией (ранее 17-я).
PHPQt
В 2015 году Александр Казанцев начал изучать алгоритмы разработки интерфейсов и создал расширение php_qml, что давало возможность использовать виджеты из библиотеки QT, но работало оно только под Windows.
С этого началась разработка PHPQt, первые версии не обратили особого внимания со стороны веб-разработчиков, поэтому автор начал углублённо улучшать расширение.
28 июля 2015 года был опубликован первый вариант компилятора проектов, на тот момент это был простой исполнитель скриптов(сценариев), который прикреплял php-код к стабу (подобно DevelStudio), и имел зависимость от Windows API, на этой стадии поддерживались уже почти все виджеты и многопоточность, была лёгкая оптимизация php-кода. С этого момента движок стали называть PQEngine,
3 августа 2016 года вышла пятая версия компилятора приложений (PqBuilder), что перешёл на базу PlastiQ и имел поддержку уже новейшего, на тот момент, php 7, проекты получили более полноценный компилятор и уже не требовали наличия PqEngine.dll вблизи с исполняемым файлом, вместо этого визуальные библиотеки стали добавляться динамично — как файлы, а не вшиваться в PQEngine.dll. Такой шаг был предпринят для совместимости с другими системами и оригинальными библиотеками Qt.
С появлением шестой версии проект стал дополнением для среды Qt Creator, а компилятор стал всего-навсего оптимизатором кода перед конечной сборкой программы. Появился полноценный редактор интерфейса, подсказки в редакторе кода и начала создаваться документация. С этого момента сделали анонс про создание среды PqStudio, но её разработка не зашла далеко.
WinForms PHP
В 2018 году появился проект, объединяющий возможности Windows Forms (.NET Framework) и PHP 7. Его разработка медленными темпами ведётся и сейчас[когда?]. На текущий момент в движке доступны практически все[какие?] функции для ООП. Среда находится на стадии приватной разработки. К исполняемому файлу по умолчанию прилагается php7ts.dll.
Подключение PHP к проекту
Также существуют расширения и для противоположного применения — подключения PHP к проекту на другом языке программирования: Phalanger (C#, php с 5.4 по 7), Peachpie] (C#, php 7), PHP4Delphi (Lazarus, Delphi, C#, C, C++, php 5.6, JPHP (Java, php 7.0), PHPly (Python, php 5.6)
Разработка PHP началась в 1993 году[37] когда датскийпрограммистРасмус Лердорф разработал на C[38] набор CGI-скриптов для учёта посетителей его онлайн-резюме, обрабатывающий шаблоны HTML-документов. Лердорф назвал набор Personal Home Page Tools (Инструменты для личной домашней страницы). Вскоре функциональности перестало хватать, и Лердорф разработал новый интерпретатор шаблонов PHP/FI (англ.Personal Home Page / Forms Interpreter — «персональная домашняя страница / интерпретатор форм»)[39].
8 июня 1995 года вышел Personal Home Page (PHP Tools) version 1.0 — первый публичный релиз с открытым исходным кодом. Эта новая реализация была способна взаимодействовать с базами данных и многое другое, что создавало фреймворк, с помощью которого пользователи могли создавать простые динамические веб-приложения.
PHP 2
В 1997 году после длительного бета-тестирования вышла вторая версия обработчика, написанного на C — PHP/FI 2.0. Её использовали всего 1 % (приблизительно 50 тысяч) всех интернет-доменов мира[9], так как к моменту выпуска языка в релиз, парсер языка был полностью переписан двумя программистами из Тель-Авива: Энди Гутмансом и Зивом Сураски.
PHP 3 и Zend Engine
Версия PHP 3.0 подверглась значительной переработке, определившей современный облик и стиль языка программирования. В 1997 году два израильских программиста, Энди Гутманс и Зеев Сураски, полностью переписали код интерпретатора. PHP 3.0 был официально выпущен в июне 1998 года[9].
Одной из сильнейших сторон PHP 3.0 была возможность расширения ядра дополнительными модулями. Впоследствии интерфейс написания расширений привлёк к PHP множество сторонних разработчиков, работающих над своими модулями, что дало PHP возможность работать с огромным количеством баз данных, протоколов, поддерживать большое число API. Большое количество разработчиков привело к быстрому развитию языка и стремительному росту его популярности. С этой версии акронимphp расшифровывается как «PHP: hypertext Preprocessor», вместо устаревшего «Personal Home Page».
К зиме 1998 года, практически сразу после официального выхода PHP 3.0, Энди Гутманс и Зеев Сураски начали переработку ядра PHP. В задачи входило увеличение производительности сложных приложений и улучшение модульности базиса кода PHP. Новый движок, названный Zend Engine, успешно справлялся с поставленными задачами и впервые был представлен в середине 1999 года.
PHP 4
PHP 4.0, основанный на движке Zend Engine и принёсший с собой набор дополнительных функций, официально вышел в мае 2000 года. В дополнение к улучшению производительности, PHP 4.0 имел ещё несколько ключевых нововведений, таких как поддержка сессий, буферизация вывода, более безопасные способы обработки вводимой пользователем информации и несколько новых языковых конструкций.
PHP 5
PHP 5 вышел 13 июля2004 года. Изменения включают обновление ядра Zend (Zend Engine 2), что существенно увеличило эффективность интерпретатора. Введена поддержка языка разметки XML. Полностью переработаны функции ООП, которые стали во многом схожи с моделью, используемой в Java. В частности, введён деструктор, открытые, закрытые и защищённые члены и методы, окончательные члены и методы, интерфейсы и клонирование объектов.
В последующих версиях также были введены пространства имён, замыкания и целый ряд достаточно серьёзных изменений, количественно и качественно сравнимых с теми, которые появились при переходе на PHP 5.0.
PHP 6
Разработка PHP 6 велась с октября 2006 года[40]. Было сделано множество нововведений[41][42], как, например, исключение из ядра регулярных выражений POSIX и «длинных» суперглобальных массивов, удаление директив safe_mode, magic_quotes_gpc и register_globals из конфигурационного файла php.ini. Одним из основных новшеств должна была стать поддержка Юникода[43]. Однако в марте 2010 года разработка PHP 6 была признана бесперспективной[44] из-за сложностей с поддержкой Юникода. Исходный код PHP 6 перемещён на ветвь, а основной линией разработки стала версия 5.4.
PHP 7
В 2014 году было проведено голосование, по результатам которого следующая версия получила название PHP 7[45]. Выход новой версии планировался в середине октября 2015 года[46]. В марте 2015 года Zend представили инфографику, в которой описаны основные нововведения PHP 7[47].
Новая версия основывается на экспериментальной ветви PHP, которая изначально называлась phpng (англ.PHP Next Generation «следующее поколение»), и разрабатывалась с упором на увеличение производительности и уменьшение потребления памяти[49]. В новой версии добавлена возможность указывать тип возвращаемых из функции данных[50], добавлен контроль передаваемых типов для данных[51], а также новые операторы.
13 июня 2019 вышла версия PHP 7.4. В ядро были добавлены типизированные свойства и стрелочные функции, а также ограниченная ковариантность возвращаемого типа и контравариантность типа аргумента[52].
PHP 8
PHP версии 8.0 была выпущена 26 ноября 2020-го[53]. Главными нововведениями стали[54]: поддержка union-типов[55], JIT-компиляция[56] и атрибуты (также известны как аннотации), как альтернатива конструкции switch было добавлено выражение match, также был добавлен новый оператор Nullsafe.
9 июля 2020 года Дэйл Хирт (англ.Dale Hirt), менеджер проекта PHP в Microsoft, в рассылке php.internals выпустил сообщение[57] о том, что после выпуска версии PHP 8.0 Microsoft прекратит поддержку разработки этого языка программирования для Windows[58]. Специалисты Microsoft занимались компиляцией бинарных версий интерпретатора для ОС Windows и тестированием их безопасности. В сообществе разработчиков PHP сообщили, что примут все необходимые меры, чтобы найти в ближайшее время альтернативный вариант для организации поддержки PHP 8.0 и выше для Windows, например, своими силами[59].
Лексический анализ PHP осуществляется посредством утилиты re2c[60][61],
утилита генерирует быстрые и легко встраиваемые лексеры.
Для написания простейшего скрипта не требуется описывать какие-либо переменные, используемые модули и т. п. Любой скрипт может начинаться непосредственно с оператора <?php, а заканчиваться оператором ?>. Закрывающий оператор не обязателен и его рекомендуется опускать, чтобы избежать проблем с отправкой лишних символов в поток вывода после выполнения основного кода.
Также возможен более короткий вариант вывода строки:
<?='Hello, world!'?>
Открывающий тег вида <?= используется для сокращённой записи конструкций, используемых для вывода строки.
Стоит обратить внимание, что хоть <?= и является сокращённой формой <?php echo, однако не является «сокращённым тегом» (таким как <?). Сокращённые теги были помечены устаревшими и их использование крайне не рекомендуется, в отличие от <?=, использование которого не будет вызывать проблем с совместимостью и переносимостью кода.
PHP исполняет код, находящийся внутри ограничителей, таких как <?php ?>. Всё, что находится вне ограничителей, выводится без изменений. В основном это используется для вставки PHP-кода в HTML-документ, например, так:
До версии 7.0 допускалось использование ограничителей языка программирования ASP<% %> и <script language="php"> </script>. Работа сокращённых конструкций определяется в конфигурационном файле php.ini.
Имена переменных начинаются с символа $, тип переменной объявлять не нужно. Имена переменных и констант чувствительны к регистру символов. Имена классов, методов классов и функций к регистру символов не чувствительны. Переменные обрабатываются в строках, заключённых в двойные кавычки, и heredoc-строках (строках, созданных при помощи оператора <<<). Переменные в строках, заключённых в одинарные кавычки и nowdoc не обрабатываются.
Инструкции разделяются с помощью точки с запятой (;), за исключением некоторых случаев, после объявления конструкции if/else и циклов.
Переменные в функцию можно передавать как по значению, так и по ссылке (используется знак &).
PHP поддерживает три типа комментариев: в стиле языка Си (ограниченные /* */), C++ (начинающиеся с // и идущие до конца строки) и оболочки UNIX (с # до конца строки).
Типы данных
PHP является языком программирования с динамической типизацией, не требующим указания типа при объявлении переменных, равно как и самого объявления переменных.
Диапазон целых чисел (int) в PHP зависит от платформы (для 32-битной архитектуры диапазон числа не превышает 32 бита, то есть, от −2 147 483 648 до 2 147 483 647). Числа можно задавать в десятичной, двоичной, восьмеричной и шестнадцатеричной системах счисления. Диапазон вещественных чисел (float) также зависит от платформы (для 32-битной архитектуры диапазон позволяет оперировать числами от ±1.7×10−308 до ±1.7×10+308).
PHP предоставляет разработчикам логический тип (bool), способный принимать только два значения true («истина») и false («ложь»). При преобразовании в логический тип число 0, пустая строка, ноль в строке «0», null и пустой массив считаются равными false. Все остальные значения автоматически преобразуются в true.
Специальный тип null предназначен для переменных без определённого значения. Единственным значением данного типа является литерал null. Тип null принимают неинициализированные переменные, переменные инициализированные константой null, а также переменные, удалённые при помощи конструкции unset().
Ссылки на внешние ресурсы имеют тип «ресурс» (resource). Переменные данного типа, как правило, представляют собой дескриптор, позволяющий управлять внешними объектами, такими как файлы, динамические изображения, результирующие таблицы базы данных и т. п. По мере развития языка стандартная библиотека постепенно дорабатывается и ресурсы заменяются объектами. Таким образом планируется полностью избавиться от этого типа.
Массивы (array) поддерживают числовые и строковые ключи и являются гетерогенными. Массивы могут содержать значения любых типов, включая другие массивы. Порядок элементов и их ключей сохраняется. Не совсем корректно называть php-массивы массивами, на самом деле это, скорее всего, упорядоченный хеш. Возможно неожиданное поведение при использовании цикла for со счётчиком вместо foreach. Так, например, при сортировке массива с численными индексами функциями из стандартной библиотеки, сортируются и ключи тоже.
Типизация
Язык допускает типизацию аргументов, возвращаемых значений функций и методов классов, а также, начиная с версии 7.4 типизацию полей классов. Включение строгого режима отключает неявные преобразования типов в данных участках кода, что приближает поведение языка к языкам со строгой типизацией.
Типы int, string, float, bool, array, object и некоторые другие являются допустимыми определениями типа аргумента, поля класса или возвращаемого значения. Также допускается использовать имена классов, либо интерфейсов для определения конкретной реализации. Использованиеresource для определения типа не допускается.
Современный PHP реализует базовую поддержку алгебраических типов данных и позволяет использовать как конъюнкцию, так и дизъюнкцию при определении типа. Язык не позволяет использовать псевдонимы типов, однако предоставляет несколько встроенных реализаций, которые в рамках PHP именуются «псевдотипами». Подобный термин в языке применяется к любому определению типа, который не является самостоятельным, применимым к значению, а реализован лишь как инструкция проверки типа в Zend VM (иногда применяется устоявшийся англицизм «тайп-хинт»).
// Для функции определён «псевдотип» mixedfunctionexample():mixed{return42;}$result=example();var_dump($result);// int(42)// Однако фактический тип у переменной $result — это int
Помимо проверок на соответствие типам встроенные «псевдотипы» могут реализовывать дополнительную логику проверок. Например, callable должен соответствовать (одному из):
анонимной функции;
строкой, которая должна содержать имя функции;
массивом где нулевой и первый элемент — строки (интерпретируется как название статической функции класса);
массивом где нулевой элемент — объект, а первый — строка (интерпретируется как метод у объекта).
Функции
PHP поддерживает как объявление именованных функций, так и анонимных функций первого класса, например:
Стоит обратить внимание, что в случае анонимных функций различие состоит не только в визуальных отличиях, но и в способе захвата переменных внешнего контекста. Любая «короткая» форма записи является замыканием, в то же время длинная запись для реализации замыкания требует явного указания переменных внутри оператора use из внешнего контекста для их захвата:
$variable='Hello World!';// Использование оператора usefunction()use($variable):string{return$variable;};// Альтернативный вариант, используя короткий синтаксисfn():string=>$variable;
Обращение к переменным и функциям
Обращение к переменным осуществляется с помощью символа $, за которым следует имя переменной. Данная конструкция может быть применена также для создания динамических переменных и функций.[63] Например:
$a='I am a';// Запись значения в переменную $aecho$a;// Вывод переменной $а$b='a';echo$$b;// Вывод переменной $а (дополнительный $ перед переменной $b)echo${'a'};// Вывод переменной $afunction_name();// Вызов функции function_name$c='function_name';$c();//Вызов функции function_name$d='ClassName';$obj=newClassName();// Создание объекта класса ClassName$obj=new$d();// Создание объекта класса ClassName$obj->b;// Обращение к свойству b объекта$obj->c();// Вызов метода c() объекта$obj->$b;// Обращение к свойству "a" объекта, так как $b = 'a'$obj->$c();// Вызов метода function_name() объекта, так как $c = 'function_name'
В PHP echo и print хоть и выглядят похоже на функции, однако первое является оператором[64], а второе выражением (то есть print возвращает значение, в отличие от echo). При их использовании можно опустить скобки.
$array=[1,2,3];array_walk($array,fn(int$value)=>print$value);// Напечатает: 123array_walk($array,fn(int$value)=>echo$value);// Ошибка: Syntax error, unexpected token "echo"// Так как тело коротких анонимных функций допускает только выражения.
Суперглобальные массивы
Суперглобальными массивами (англ.Superglobal arrays) в PHP называются предопределённые массивы, имеющие глобальную область видимости без использования директивы global. Большая часть этих массивов содержит входные данные запроса пользователя (параметры GET-запроса, поля форм при посылке методом POST, куки и т. п.).
Все суперглобальные массивы, кроме $GLOBALS и $_REQUEST, имеют устаревшие аналоги с длинными именами, которые доступны вплоть до версии 5.3. х (начиная с 5.4.0 были удалены). Таким образом, обращения $_GET['year'] и $HTTP_GET_VARS['year'] идентичны (за исключением области видимости: массивы с «длинными» именами не являются суперглобальными).
$GLOBALS
Массив всех глобальных переменных (в том числе и пользовательских).
$_SERVER (аналог для устаревшего — $HTTP_SERVER_VARS)
Содержит переменные окружения, которые операционная система передаёт серверу.
$_ENV (уст. $HTTP_ENV_VARS)
Текущие переменные среды (англ.Environment variables). Их набор специфичен для платформы, на которой выполняется скрипт.
$_GET (уст. $HTTP_GET_VARS)
Содержит параметры GET-запроса, переданные в URI после знака вопроса «?».
$_POST (уст. $HTTP_POST_VARS)
Ассоциативный массив значений полей HTML-формы при отправке методом POST. Индексы элементов соответствуют значению свойства name объектов (кнопки, формы, радиокнопки, флажки и т. д.) HTML-формы.
$_FILES (уст. $HTTP_POST_FILES)
Ассоциативный массив со сведениями об отправленных методом POST файлах. Каждый элемент имеет индекс, идентичный значению атрибута «name» в форме, и, в свою очередь, также является массивом со следующими элементами:
['name'] — исходное имя файла на компьютере пользователя.
['type'] — указанный агентом пользователя MIME-тип файла. PHP не проверяет его, и поэтому нет никаких гарантий, что указанный тип соответствует действительности.
['size'] — размер файла в байтах.
['tmp_name'] — полный путь к файлу во временной папке. Файл необходимо переместить оттуда функцией move_uploaded_file. Загруженные файлы из временной папки PHP удаляет самостоятельно.
['error'] — код ошибки. Если файл удачно загрузился, то этот элемент будет равен 0 (UPLOAD_ERR_OK).
$_COOKIE (уст. $HTTP_COOKIE_VARS)
Ассоциативный массив с переданными агентом пользователя значениями куки.
$_REQUEST
Содержит элементы из массивов $_GET, $_POST, $_COOKIE. С версии PHP 4.1 включает $_FILES.
$_SESSION (уст. $HTTP_SESSION_VARS)
Содержит данные сессии.
Объектно-ориентированное программирование
Ключевое слово class было зарезервировано ещё в третьей версии языка.
В четвёртой версии стало возможно создавать классы и объекты на их основе. Однако принципы ООП поддерживались лишь частично, так например, все члены (переменные и методы) были открыты. К тому же создание объектов было дорогой операцией и работало медленно.
Начиная с пятой версии PHP обладает полной поддержкой ООП. Работа с классами была оптимизирована и теперь такой код работает достаточно быстро.
Класс в PHP объявляется с помощью ключевого слова class. Методы и свойства класса могут быть общедоступными (public, по умолчанию), защищёнными (protected) и скрытыми (private). PHP поддерживает все три основных механизма ООП — инкапсуляцию, полиморфизм подтипов и наследование (родительский класс указывается с помощью ключевого слова extends после имени класса). Поддерживаются интерфейсы (ставятся в соответствие с помощью implements). Разрешается объявление финальных, абстрактных методов и классов. Множественное наследование классов не поддерживается, однако класс может реализовывать несколько интерфейсов. Для обращения к методам родительского класса используется ключевое слово parent.
Начиная с версии 5.4.0 множественное наследование может быть реализовано с помощью механизма особенностей (англ.trait). Особенности похожи на примеси (англ.mixins), за исключением того что для них нельзя напрямую создать экземпляр. Повторное использование кода заключено в использовании кода особенности в нескольких классах. Допускается использовать в одном классе несколько особенностей. Механизм особенностей имеет средства разрешения конфликтов имён. При запуске программы код особенности будет «вкомпилирован» в код содержащего его класса.
Классы в PHP имеют ряд «магических» методов (англ.magic methods), начинающихся с двух символов подчёркивания — конструктор (__construct(), в версиях до 5.0 конструктором служил метод, одноимённый с классом) и деструктор (__destruct()), а также методы чтения (__get()) и записи (__set()), свёртывания (__sleep()) и развёртывания (__wakeup()), клонирования (__clone()) и др. Эти методы являются достаточно гибким инструментом: переопределяя их, можно добиться существенного изменения поведения объекта.
Все функции-члены реализованы виртуальными и потому все они являются методами.
Экземпляры класса создаются с помощью ключевого слова new, обращение к полям и методам объекта производится с использованием оператора ->. Для доступа к членам класса из его методов используется переменная $this.
Начиная с пятой версии PHP объекты передаются по указателю:
classA{publicstring$color='red';}$a=newA();echo$a->color;// red$b=$a;$b->color='blue';echo$a->color;// blue
Иногда также можно встретить упоминание, что объекты передаются по ссылке, однако это не так. Так как в PHP отсутствует понятие «указателя», то может применяться терминология «передачи по ссылке» в контексте передачи объектов в качестве аргументов функций или методов из-за схожести поведения. Отличия между передачей объектов по ссылке и по указателю выглядят следующим образом:
classA{}functionby_pointer(A$object):void{$object=42;}functionby_reference(A&$object):void{$object=42;}$object=newA();// Передача по указателюby_pointer($object);var_dump($object);// object(A) {}// Передача по ссылкеby_reference($object);var_dump($object);// int(42)
«Paamayim Nekudotayim» (иврит: פעמיים נקודתיים) или просто «двойное двоеточие». Используя эту лексему, программист может обращаться к константам, статическим или перегруженным свойствам или методам класса.
При обращении к этим элементам извне класса программист должен использовать имя этого класса.
«Paamayim Nekudotayim» на первый взгляд может показаться странным словосочетанием для обозначения двойного двоеточия. Однако во время создания Zend Engine версии 0.5 (который входил в PHP3), Andi и Zeev выбрали[65] именно это обозначение. «Paamayim Nekudotayim» действительно значит «двойное двоеточие» (дословно: «два раза двоеточие») на иврите. Это обозначение не менялось ни разу в течение всего времени разработки PHP[66].
classMyClass{publicconstCONST_VALUE='Значение константы';}// Использование :: вне объявления классаechoMyClass::CONST_VALUE;
выполнение опкода интерпретатором (без создания исполняемого файла), либо JIT-компиляция результата с последующим выполнением (для включения JIT требуется специальный флаг в настройках интерпретатора).
Раньше, для увеличения быстродействия приложений было возможно использование специального программного обеспечения, так называемых акселераторов. Принцип их работы заключается в кэшировании однажды сгенерированного байт-кода в памяти и/или на диске, таким образом, из процесса работы приложения исключаются этапы 1—3, что в общем случае ведёт к значительному ускорению работы. Начиная с версии 5.5 одна из разновидностей акселераторов, opcache, была встроена в ядро, поэтому сторонние решения больше не пользуются популярностью.
Важной особенностью является то, что разработчику нет необходимости заботиться о распределении и освобождении памяти. Ядро PHP реализует средства для автоматического управления памятью; вся выделенная память возвращается системе после завершения работы скрипта[67].
Расширения
Интерпретатор состоит из ядра и подключаемых модулей, «расширений», представляющих собой динамические библиотеки. Расширения позволяют дополнить базовые возможности языка, предоставляя возможности для работы с базами данных, сокетами, динамической графикой, криптографическими библиотеками, документами формата PDF и тому подобным. Любой желающий может разработать своё собственное расширение и подключить его. Существует огромное количество расширений, как стандартных, так и созданных сторонними компаниями и энтузиастами, однако в стандартную поставку входит лишь несколько десятков хорошо зарекомендовавших себя. Множество расширений доступно в репозитории PECL.
Начиная с версии 7.4.0 в PHP была добавлена поддержка интерфейса внешних функций (FFI), что в значительной степени упростило взаимодействие с библиотеками, написанными на любом другом языке (включая API, предоставляемое операционной системой). Этот новый функционал, в свою очередь, предоставил альтернативу написанию расширений. Таким образом, используя FFI можно писать код на языке PHP и взаимодействовать с любыми библиотеками в системе, которые предоставляют cdecl, fastcall или stdcallABI.
Параметры настройки
Интерпретатор PHP имеет специальный конфигурационный файл — php.ini, содержащий множество настроек, изменение которых влияет на поведение интерпретатора[68]. Имеется возможность отключить использование ряда функций, изменить ограничения на используемую скриптом оперативную память, время выполнения, объём загружаемых файлов, настроить журналирование ошибок, работу с сессиями и почтовыми сервисами, подключить дополнительные расширения, а также многое другое. Возможно дробление большого конфигурационного файла на части. Например, широко распространена практика вынесения настроек расширений в отдельные файлы. Параметры интерпретатора могут быть переопределены в файлах конфигурации HTTP-сервера (например, .htaccess в Apache) или в самом скрипте во время выполнения при помощи команды ini_set[69].
Режимы запуска интерпретатора (SAPI)
SAPI — это внешний уровень абстракции, предназначенный для встраивания интерпретатора в другие приложения и отвечает за его работу (запуск, остановка, передача скриптов на исполнение, доступ к внешним данным). Существует несколько основных SAPI, определяющих способы запуска и использования PHP:
В качестве модуля к веб-серверу (например, для Apache модуль mod_php). В этом случае интерпретатор PHP выполняется в окружениипроцесса веб-сервера. Веб-сервер управляет количеством запущенных процессов PHP и сообщает им, какие скрипты требуется исполнить.
CGI SAPI. Использование CGI подразумевает запуск нового процесса для обработки каждого запроса. Для исполнения PHP-скрипта веб-сервер запускает ./php-cgi /path/to/script.php . Сам принцип такого использования подразумевает, что интерпретатор PHP исполняет только один скрипт, после чего заканчивает свою работу. Затраты на запуск процесса интерпретатора и его инициализацию очень часто сопоставимы или даже превышают затраты на исполнение PHP-скрипта. Для решения этой проблемы в CGI SAPI был введён режим FastCGI. В этом режиме PHP-интерпретатор запускается как независимый сервер, обрабатывающий входящие запросы на исполнение PHP-скриптов по протоколу FastCGI, что позволяет ему работать с любым веб-сервером, поддерживающим этот протокол.
FPM SAPI, известный как php-fpm — это другая реализация протокола FastCGI. Создан изначально Андреем Нигматулиным как отдельный патч для использования в социальной сети Badoo. Данная реализация решала ряд проблем, которые мешали использованию CGI/FastCGI SAPI. В частности, появилась возможность перезапуска пула интерпретаторов PHP без потери запросов, запуск нескольких пулов под разными пользователями, аварийный перезапуск интерпретаторов в случае проблем с ними и ещё несколько приятных дополнений. В дальнейшем над патчем работали несколько человек, был добавлен режим динамического управления числом запущенных процессов PHP (по принципу управления числом процессов в веб-сервере Apache), и начиная с версии PHP 5.3.3 php-fpm был включён в PHP как отдельное SAPI.
Начиная с версии PHP 5.4.0 в CLI SAPI появилась возможность запуска PHP как отдельного HTTP-сервера. Однако этот режим предназначен исключительно для разработки, так как запускает только один процесс интерпретатора и выполняет все запросы исключительно последовательно.
Пасхальные яйца
PHP имеет несколько пасхальных яиц (шуток). Передача специальных GET-параметров любому php-скрипту приводит к выводу различных изображений.
В силу популярности языка PHP и желания увеличить быстродействие основанных на нём веб-приложений создано несколько альтернативных компиляторов, близких к PHP-языку. Так в феврале 2010 года компания Facebook открыла[72][73] свой компилятор PHP — HipHop (HPHP, Hyper-PHP) генерирующий код на C++, с последующей компиляцией в машинный код с помощью gcc. В июле 2013 года российская компания ВКонтакте анонсировала похожий продукт — KPHP[74].
В таблице представлен список существующих на сегодняшний момент альтернативных реализаций.
Стандартные рекомендации PHP (англ.PHP Standard Recommendation, сокр. PSR[англ.]) — это спецификация PHP, которая разрабатывается, принимается и публикуется группой авторитетных PHP проектов в том числе
CakePHP, Composer, Joomla, PEAR, Phalcon, phpDocumentor, TYPO3, Yii framework[83]. Спецификация служит стандартизацией концепций программирования на языке PHP и основана на реальном опыте, а также на исследованиях и экспериментах[84]. Цель рекомендаций состоит в том, чтобы обеспечить совместимость компонентов веб-приложений разработанных разными разработчиками.
Критика
Сторонники языка PHP в качестве основных его преимуществ называют широкую распространённость, востребованность PHP-разработчиков на рынке труда и простоту изучения. К достоинствам языка относится и его достаточно быстрая эволюция.
Отсутствие поддержки многобайтовых кодировок в ядре языка
Поддержка строк с многобайтовыми кодировками (такими как UTF-8) реализуется через отдельные расширения mbstring и iconv, на уровне ядра поддержка отсутствует, однако с версии PHP 4.2.0 есть возможность переопределять стандартные функции работы со строками, подменяя их на аналоги из mbstring.
Поддержка многобайтовых кодировок во всех строковых функциях стала доступна с версии 5.4.0 (март 2012 года).
Отсутствие поддержки многопоточности
В языке не предусмотрена возможность создания многопоточных приложений и отсутствует поддержка синхронизированного доступа к ресурсам, однако реализуема при помощи расширения PCNTL[85] (от англ.process control), но оно не подходит для решения специфических задач.
Хотя есть возможность установить расширение pthreads для «честных» потоков, но для этого интерпретатор должен быть скомпилирован с флагом thread safety, а само расширение признано устаревшим в пользу parallel (от того же автора).
В качестве более современной альтернативы возможно использование расширения Swoole.
↑По-видимому, позаимствовали из языка C++, где это бинарная форма указания области видимости, конструкция с ним, квалифицированным именем, в данном случае константы.
↑PCNTL (неопр.). Дата обращения: 23 января 2012. Архивировано 17 января 2012 года.
Литература
Мэтт Зандстра. PHP: объекты, шаблоны и методики программирования = PHP Objects, Patterns and Practice, Third Edition. — 3-е издание. — М.: «Вильямс», 2010. — С. 560. — ISBN 978-5-8459-1689-1.
Кристиан Дари, Эмилиан Баланеску. PHP и MySQL: создание интернет-магазина = Beginning PHP and MySQL E-Commerce: From Novice to Professional. — М.: «Вильямс», 2010. — ISBN 978-5-8459-1602-0.
Джейсон Ленгсторф. PHP и jQuery для профессионалов = Pro PHP and jQuery. — М.: «Вильямс», 2010. — С. 352. — ISBN 978-5-8459-1693-8.
Квентин Зервас. Web 2.0: создание приложений на PHP = Practical Web 2.0 Applications with PHP. — М.: «Вильямс», 2009. — С. 544. — ISBN 978-5-8459-1590-0.
Кузнецов Максим, Симдянов Игорь. Объектно-ориентированное программирование на PHP. — СПб.: «БХВ-Петербург», 2007. — С. 608. — ISBN 978-5-9775-0142-2.
Эд Леки-Томпсон, Алек Коув, Стивен Новицки, Хьяо Айде-Гудман. PHP 5 для профессионалов = Professional PHP 5. — М.: «Диалектика», 2006. — С. 608. — ISBN 0-7645-7282-2.
Кузнецов Максим, Симдянов Игорь. Самоучитель PHP 5/6. — 3-е изд., перераб. и доп. — СПб.: «БХВ-Петербург», 2009. — С. 672. — ISBN 978-5-9775-0409-6.
Кузнецов Максим, Симдянов Игорь. PHP. Практика создания Web-сайтов. — 2-е изд. перераб. и доп. — СПб.: «БХВ-Петербург», 2008. — С. 1264. — ISBN 978-5-9775-0203-0.
Кузнецов Максим, Симдянов Игорь. Головоломки на PHP для хакера. — 2-е изд. перераб. и доп. — СПб.: «БХВ-Петербург», 2008. — С. 544. — ISBN 978-5-9775-0204-7.
Кузнецов Максим, Симдянов Игорь. PHP на примерах. — 2-е изд. перераб. и доп. — СПб.: «БХВ-Петербург», 2011. — С. 400. — ISBN 978-5-9775-0445-4.
Люк Веллинг, Лора Томсон. Разработка веб-приложений с помощью PHP и MySQL. — 5-е изд.. — СПб.: «Диалектика», 2019. — С. 768. — ISBN 978-5-9908911-9-7.
Никсон Р. Создаём динамические веб-сайты с помощью PHP, MySQL, JavaScript, CSS и HTML5. — 4-е изд.. — СПб.: «Бестселлеры O’Reilly», 2016. — С. 768. — ISBN 978-5-496-02146-3.
Ульман,Ларри. РНР и MySQL: создание интернет-магазинов. — 2-е изд.. — СПб., 2015. — С. 544. — ISBN 978-5-8459-1939-7.
Кузнецов М., Симдянов И. Самоучитель PHP 7. — 2-е изд.. — СПб., 2018. — С. 448. — ISBN 978-5-9775-3817-6.
دوري أبطال أوروبا 2017–18تفاصيل المسابقةالتواريخالتصفيات:27 يونيو – 23 أغسطس 2017المنافسة الرسمية:12 سبتمبر 2017–26 مايو 2018الفرقالمنافسة الرسمية: 32المجموع: 79 (من 54 اتحاد)المراكز النهائيةالبطل ريال مدريدالوصيف ليفربولإحصائيات المسابقةالمباريات الملعوبة125الأهداف المسجلة401&...
Dewan Perwakilan Rakyat Daerah Kabupaten DharmasrayaDewan Perwakilan Rakyat Kabupaten Dharmasraya 2019-2024JenisJenisUnikameral SejarahSesi baru dimulai14 Agustus 2019PimpinanKetuaPariyanto, S.H. (PDI-P) sejak 20 November 2019 Wakil Ketua IIr. H. Adi Gunawan, M.M. (Golkar) sejak 8 Oktober 2019 Wakil Ketua IIH. Benny Ridwan (PAN) sejak 8 Oktober 2019 KomposisiAnggota30Partai & kursi PDI-P (7) NasDem (3) PKB (1) Hanura (1) ...
Japan: Districts / Prefectures Template‑class Japan portalThis template is within the scope of WikiProject Japan, a collaborative effort to improve the coverage of Japan-related articles on Wikipedia. If you would like to participate, please visit the project page, where you can join the project, participate in relevant discussions, and see lists of open tasks. Current time in Japan: 22:48, April 9, 2024 (JST, Reiwa 6) (Refresh)JapanWikipedia:WikiProject JapanTemplate:WikiProject JapanJapa...
2018 song by Nicki Minaj For the song by Future, see DS2 (album). Rich SexPromotional single by Nicki Minaj featuring Lil Waynefrom the album Queen ReleasedJune 11, 2018 (2018-06-11)Genre Dirty rap trap Length3:12Label Young Money Cash Money Songwriter(s) Onika Maraj Dwayne Carter Aubry Big Juice Delaine Jawara Headley Jeremy Reid Producer(s) Big Juice J. Reid Nicki Minaj chronology Yasss Bish (2014) Rich Sex (2018) Fendi (2019) Rich Sex is a song by Trinidadian-born rapper Nic...
Alawite ruler of Tafilalt from 1631–1636 مولايَ الشَّرِيف بْن عَلِيّMoulay Sharif ibn AliEmir of TafilaltReign1631–1636SuccessorSidi Muhammad ibn SharifBorn1589Tafilalt, MoroccoDied4 June 1659Sijilmasa, MoroccoIssueSidi Muhammad ibn Sharif Al-Rashid of MoroccoIsmail Ibn SharifNamesMoulay Mohammed ech-Cherif ben Ali ben Mohammed al-Alaoui[1][2]HouseHouse of AlaouiReligionIslam Abul Amlak Moulay Sharif ibn 'Ali[3][a] (Arabic: مولا�...
Artikel ini sebatang kara, artinya tidak ada artikel lain yang memiliki pranala balik ke halaman ini.Bantulah menambah pranala ke artikel ini dari artikel yang berhubungan atau coba peralatan pencari pranala.Tag ini diberikan pada Februari 2023. Prasasti Ratawun berupa te.ditemukanbaga di daerah Magelang, Jawa Tengah tahun 1870. Prasasti ini sekarang disimpan di Museum Nasional Jakarta dengan nomor inventaris [E. 9]. Ukurannya 36 x 20.5 cm. ditulisi dikedua sisinya. Sisi muka 13 baris, s...
Neighborhood of San Francisco in California, United StatesGlen ParkNeighborhood of San FranciscoView of Glen Park from Diamond Street by Bosworth Street.Glen ParkLocation within San FranciscoCoordinates: 37°44′02″N 122°26′00″W / 37.73389°N 122.43333°W / 37.73389; -122.43333Country United StatesState CaliforniaCity-countySan FranciscoGovernment • SupervisorRafael Mandelman[1] • AssemblymemberMatt Haney (D)[2&...
Pour les articles homonymes, voir Boyle. Robert BoylePortrait de Robert Boyle.BiographieNaissance 25 janvier 1627Lismore CastleDécès 31 décembre 1691 (à 64 ans)LondresSépulture St Martin-in-the-FieldsÉpoque Génération du XVIIe siècle (d)Nationalité IrlandaisDomiciles Comté de Waterford, AngleterreFormation Collège d'Eton (à partir de 1635)Activités Physicien, chimiste, philosophePère Richard BoyleMère Catherine Fenton BoyleFratrie Richard BoyleKatherine Jones (en)Roger B...
Ця стаття потребує додаткових посилань на джерела для поліпшення її перевірності. Будь ласка, допоможіть удосконалити цю статтю, додавши посилання на надійні (авторитетні) джерела. Зверніться на сторінку обговорення за поясненнями та допоможіть виправити недоліки. Мат...
Group of West Germanic languages North Sea GermanicIngvaeonic, Ingveonic,[1] coastal Germanic[1]GeographicdistributionOriginally the North Sea coast from Friesland to Jutland; today, worldwideLinguistic classificationIndo-EuropeanGermanicWest GermanicNorth Sea GermanicSubdivisions Anglo-Frisian Low German Glottolognort3175The distribution of the primary Germanic languages in Europe c. AD 1: North Germanic North Sea Germanic, or Ingvaeonic ...
Rugby league competition Rugby league season 1936 New South Wales Rugby Football LeagueTeams9Premiers Eastern Suburbs (6th title)Minor premiers Eastern Suburbs (7th title)Matches played63Points scored1956Top points scorer(s) Syd Christensen (123)Top try-scorer(s) Fred Tottey (25)← 19351937 → The 1936 New South Wales Rugby Football League premiership was the twenty-ninth season of Sydney’s top-level rugby league football club competition, Australia’s first. Nine teams from ac...
هفيزد هفيزد (إفانو-فرانكيفسكا) هفيزد (إفانو-فرانكيفسكا) تقسيم إداري البلد أوكرانيا [1] خصائص جغرافية إحداثيات 48°40′53″N 24°32′38″E / 48.681388888889°N 24.543888888889°E / 48.681388888889; 24.543888888889 المساحة 1455 كيلومتر مربع الارتفاع 399 متر معلومات أخرى التوقيت ت ع م+02:00 (...
German philosopher (1762–1814) Fichte redirects here. For other uses, see Fichte (disambiguation). Johann Gottlieb FichteBorn(1762-05-19)19 May 1762Rammenau, Saxony, Holy Roman EmpireDied29 January 1814(1814-01-29) (aged 51)Berlin, Brandenburg, Prussia, German ConfederationNationalityGermanEducationSchulpfortaUniversity of Jena(1780; no degree)Leipzig University(1781–1784; no degree)Era18th-century philosophySchoolGerman idealismInstitutionsUniversity of JenaUniversity of ErlangenUni...
Untuk politikus Britania Raya, lihat John Cryer. Jon CryerCryer di acara Hollywood Walk of Fame pada 19 September 2011LahirJonathan Niven Cryer16 April 1965 (umur 59)New York City, ASPekerjaanPemeran, sutradara televisi, pelawakTahun aktif1984–sekarangSuami/istri Sarah Trigger (m. 1999; bercerai 2004) Lisa Joyner (m. 2007) Anak2 Jonathan Niven Cryer (lahir 16 April 1965)[1] adalah se...
Iranian-born American mathematician Alexander AbianBornAlexander (Smbat) Abian(1923-01-01)January 1, 1923Tabriz, IranDiedJuly 24, 1999(1999-07-24) (aged 76)Ames, Iowa, U.S.Other namesSmbat AbianOccupationProfessor at Iowa State University Alexander (Smbat) Abian (January 1, 1923 – July 24, 1999)[1] was an Iranian-born Armenian-American mathematician who taught for over 25 years at Iowa State University and became notable for his frequent posts to various Usenet newsgro...
American thoroughbred horse race Horse race 105th Belmont StakesBelmont StakesGrade I stakes raceSecretariat on the final stretchLocationBelmont ParkElmont, New York, U.S.DateJune 9, 1973Distance1+1⁄2 mi (12 furlongs; 2,414 m)Winning horseSecretariatWinning time2:24JockeyRon TurcotteTrainerLucien LaurinOwnerPenny CheneryConditionsFastSurfaceDirtAttendance69,138← 19721974 → The 1973 Belmont Stakes was the 105th running of the Belmont Stakes at Belmont Park...
Soviet transport helicopter Mi-4 Mil Mi-4 at Prague Aviation MuseumGeneral informationTypeTransport helicopterManufacturerMil Moscow Helicopter PlantStatusLimited Service; North Korean Air ForcePrimary usersSoviet Air Force Polish Air Force Royal Afghan Air Force Number builtover 4,000 including Z-5sHistoryManufactured1951–1979Introduction date1953First flight3 June 1952VariantsHarbin Z-5 The Mil Mi-4 (USAF/DoD reporting name Type 36,[1] NATO reporting name Hound)[2][3...