Php строки двойные кавычки

Строки — Основы PHP

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

Что такое строка

Какие из этих пяти вариантов — строки?

С первыми двумя все понятно, это точно строки, мы уже работали с подобными конструкциями и говорили, что строки – это наборы символов.

Любой одиночный символ в кавычках — это строка, например ‘G’ . Пустая строка » — это тоже строка. То есть строкой мы считаем все, что находится внутри кавычек, даже если это пробел, один символ или вообще отсутствие символов.

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

Разберем, почему у обозначения строки есть два способа.

Зачем нужны двойные кавычки

Представим, что нам нужно напечатать строчку dragon’s mother . Апостроф перед буквой s — это такой же символ, как одинарная кавычка. Попробуем:

 print_r('Dragon's mother'); // PHP Parse error: syntax error, unexpected 's' (T_STRING), expecting ',' or ')' 

Такая программа не будет работать. С точки зрения PHP строчка началась с одинарной кавычки, а потом закончилась после буквы n. Дальше были символы s mother без кавычек — значит, это не строка. А потом была одна открывающая строку кавычка, которая так и не закрылась: ‘); . Этот код синтаксически некорректен.

Здесь помогут двойные кавычки. Такой вариант программы отработает корректно:

Теперь интерпретатор знает, что строка началась с двойной кавычки, значит, завершиться должна на двойной кавычке. А одинарная кавычка внутри стала частью строки.

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

Читайте также:  Php mysql вложенные транзакции

Теперь представим, что мы хотим создать такую строку:

В ней есть и одинарные, и двойные кавычки. В этой ситуации нужно указать интерпретатору, что нужно считать каждую кавычку частью строки, а не началом или концом.

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

 // Экранируется только ", так как в этой ситуации // двойные кавычки имеют специальное значение print_r("Dragon's mother said \"No\""); // => Dragon's mother said "No" 

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

 // \ выводится, если после него идет обычный, // а не специальный символ print_r("Death is \so terribly final"); // => Death is \so terribly final 

Также нам может понадобиться вывести сам обратный слеш:

Это тоже можно сделать через экранирование, но уже самого себя.

Что такое экранирующие последовательности

Иногда нам необходимо расположить несколько строк друг за другом. Для этого нужно сказать интерпретатору «нажать на энтер» — сделать перевод строки после вопросительного знака. Это можно сделать с помощью символа перевода строки — \n :

 print_r("- Are you hungry?\n- Aaaarrrgh!"); 
- Are you hungry? - Aaaarrrgh! 

\n — это специальный символ. В литературе его часто обозначают как LF (Line Feed). С точки зрения компьютера — это один невидимый символ перевода строки:

 // Мы это не изучали, но вы должны знать правду // Ниже код, который возвращает длину строки strlen("a"); // 1 strlen("\n"); // 1 . strlen("\n\n"); // 2 . 

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

Читайте также:  Php pdo connect to sql server

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

\n — это пример экранирующей последовательности (escape sequence). Их еще называют управляющими конструкциями. Таких символов не один десяток, но в программировании часто встречаются всего несколько. Программистам часто нужно использовать перевод строки \n для правильного форматирования текста.

Экранирующие последовательности вроде \n работают только внутри двойных кавычек.

Если нам понадобится вывести \n именно как текст, то можно воспользоваться уже известным нам способом экранирования — добавить еще один \ в начале. В итоге последовательность \\n отобразится как символы \ и n , которые идут друг за другом.

В Windows для перевода строк по умолчанию используется \r\n . Такая комбинация хорошо работает только в Windows, но создает проблемы при переносе в другие системы. Например, когда в команде разработчиков есть пользователи как Windows, так и Linux.

Последовательность \r\n имеет разную трактовку в зависимости от выбранной кодировки. Это мы рассмотрим позже. По этой причине в среде разработчиков принято всегда использовать \n без \r , так как LF всегда трактуется одинаково и отлично работает в любой системе. Поэтому нужно настроить свой редактор на использование \n .

Что такое конкатенация

В веб-разработке программы постоянно оперируют строками. Все, что мы видим на сайтах, так или иначе представлено в виде текста. Этот текст чаще всего динамический — полученный из разных частей, которые соединяются вместе. Операция соединения строк в программировании называется конкатенацией.

Мы уже знаем о математической операции сложения:

Читайте также:  Formatting tools in html

Такая программа выведет на экран 8 — результат работы бинарного оператора + с операндами 5 и 3 .

Можно также «сложить» две строки. Такая программа выведет на экран Dragonstone — результат работы бинарного оператора . с операндами ‘Dragon’ и ‘stone’:

 print_r('Dragon' . 'stone'); // => Dragonstone 

Склеивание строк всегда происходит в том же порядке, в котором записаны операнды. Левый операнд становится левой частью строки, а правый — правой. Вот еще несколько примеров:

 print_r('Kings' . 'wood'); // => Kingswood print_r('Kings' . 'road'); // => Kingsroad print_r("King's" . 'Landing'); // => King'sLanding 

Строки можно склеивать, даже если они записаны с разными кавычками.

Пробел — такой же символ, как и другие, поэтому сколько пробелов поставить в строке — столько и получится в итоговой строке:

 // Ставим пробел в левой части print_r("King's " . 'Landing'); // => King's Landing // Ставим пробел в правой части print_r("King's" . ' Landing'); // => King's Landing 

Выводы

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

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

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

Также мы узнали, что в коде можно не только складывать цифры, но и строки. Операция соединения строк в программировании называется конкатенацией.

Дополнительные материалы

Остались вопросы? Задайте их в разделе «Обсуждение»

Вам ответят команда поддержки Хекслета или другие студенты

Источник

Оцените статью