Область видимости переменной это контекст, в котором она определяется.
Как правило все переменные PHP имеют единую область видимости. Эта единая область
видимости включает также include и required/необходимые файлы. Например:
Здесь переменная
$a будет доступна внутри включаемого/include скрипта b.inc.
Однако внутри пользовательских функций вводится также локальная область видимости
функции. Любая переменная, используемая внутри функции, по умолчанию имеет ограниченную
локальную область видимости в пределах функции. Например: Накопитель
на жестком магнитном диске (НМД)
$a = 1; /* глобальная область видимости */ function Test() { echo
$a; /* ссылка на переменную локальной области видимости */ } Test(); |
Читальный зал Этот
скрипт не производит никакого вывода, так как оператор echo ссылается на локальную
версию переменной $a, а ей не присвоено значение в пределах этой области
видимости. Вы можете заметить, что это слегка отличается от языка C тем, что глобальные
переменные C автоматически доступны функциям, если только не переопределяются
специально локальным определением. Это иногда создаёт проблемы, если неумышленно
изменить глобальную переменную. В PHP глобальные переменные обязаны быть определены
внутри функции, если они будут использоваться в этой функции. Пример: Скульптура
Первый расцвет буддийской скульптуры относится к VIII столетию, когда был построен
столичный город Хэйдзё-кё. К тому времени японская скульптура имела уже вековой
опыт создания разнообразных статуй буддийских божеств, которые делали из бронзы,
дерева, лака. В 743 г. начали сооружать колоссальную статую Будды, предназначенную
для храмового ансамбля Тодайдзи.
$a = 1; $b = 2; function Sum() { global $a, $b; $b = $a + $b; }
Sum(); echo $b; |
Этот скрипт выведет "3". При определении
$a и $b как global внутри функции, все ссылки на любую переменную
будут ссылаться на глобальную версию. Нет ограничений на количество глобальных
переменных, которые могут обрабатываться в функции. Теоретическая механика Принцип
кинетостатики (принцип Даламбера) Принцип кинетостатики используют для упрощения
решения ряда технических задач. Реально силы инерции приложены к телам, связанным
с разгоняющимся телом (к связям). Даламбер предложил условно прикладывать силу
инерции к активно разгоняющемуся телу. Тогда система сил, приложенных к материальной
точке, становится уравновешенной, и можно при решении задач динамики использовать
уравнения статики.
Второй способ доступа к глобальным переменным глобальной
области видимости - использовать специальный определяемый PHP массив $GLOBALS.
Предыдущий пример можно записать так:
$a = 1; $b = 2; function Sum() { $GLOBALS["b"] = $GLOBALS["a"]
+ $GLOBALS["b"]; } Sum(); echo $b; |
Массив $GLOBALS
является ассоциативным массивом с именем глобальной переменной как ключом/key
и содержимым этой переменной как значением/value элемента этого массива.
Другой
важной особенностью области видимости переменной является static/статическая
переменная. Статическая переменная существует только в локальной области видимости
функции, но не теряет своего значения, когда программа выходит из этой области
видимости. Рассмотрим пример:
function Test () { $a = 0; echo $a; $a++; } |
Эта
функция практически бесполезна, поскольку каждый раз при её вызове $a
устанавливается в 0 и печатается "0". Операция $a++, которая
выполняет инкремент переменной, реально не нужна, так как при выходе из функции
переменная $a исчезает. Чтобы функция не теряла текущего значения счётчика,
переменная $a объявляется как static:
function Test() { static $a = 0; echo $a; $a++; } |
Теперь при каждом вызове функции Test() она будет печатать значение
$a и выполнять инкремент.
Static-переменные позволяют также работать
с рекурсивными функциями. Рекурсивной является функция, которая вызывает сама
себя. При написании таких функций нужно быть внимательным, поскольку есть вероятность
сделать рекурсию бесконечной. Вы обязаны убедиться, что имеется адекватный способ
прерывания рекурсии. Следующая функция рекурсивно вычисляется до 10 с использованием
статической переменной $count:
function Test() { static $count = 0; $count++; echo $count; if
($count < 10) { Test (); } $count--; } |
Zend-Машина
1, выполняющая работу PHP4, реализует модификаторы static и
global для переменных в терминах ссылок. Например, правильная глобальная
переменная, импортированная внутрь области видимости функции оператором global,
создаёт в действительности ссылку на эту глобальную переменную. Это может привести
к неожиданным результатам, как показано в примере:
function test_global_ref() { global $obj; $obj = &new stdclass;
} function test_global_noref() { global $obj; $obj = new stdclass; } test_global_ref();
var_dump($obj); test_global_noref(); var_dump($obj); |
java_last_exception_clear java_last_exception_get
jddayofweek jdmonthname
jdtofrench jdtogregorian
jdtojewish jdtojulian
jdtounix jewishtojd
join jpeg2wbmp juliantojd
key krsort ksort
Переменные переменные
Иногда удобно иметь переменные как имена
переменных. То есть имена переменных, которые могут устанавливаться и использоваться
динамически. Нормальная переменная устанавливается примерно таким оператором:
Переменная переменная/variable
variable принимает значение переменной и рассматривает его как имя переменной.
В предыдущем примере, hello может использоваться как имя переменной с помощью
двух знаков dollar. То есть:
После этого в дереве
символов РНР определены две переменные: $a с содержимым "hello" и $hello
с содержимым "world". Следовательно, оператор
даст тот же вывод,
что и
то есть оба они дадут на выходе: hello
world
Чтобы использовать переменные переменные с массивами, вы должны
разрешить проблему неоднозначности. То есть, если вы записываете $$a[1],
то разборщику необходимо знать, будете ли вы использовать $a[1] как переменную,
или вы хотите использовать $$a как переменную, а затем как индекс [1]
из этой переменной. Синтаксис для разрешения этой неоднозначности таков: ${$a[1]}
для первого случая и ${$a}[1] - для второго.
Пожалуйста отметьте,
что переменные переменные не могут использоваться с новыми суперглобалами РНР.
Это значит, что вы не можете делать что-либо вроде ${$_GET}. Если вы
ищете способ работать с superglobals и старыми HTTP_*_VARS, вы можете попытаться
ссылаться на них.
lcg_value
ldap_8859_to_t61 ldap_add
ldap_bind ldap_close
ldap_compare ldap_connect
ldap_count_entries ldap_delete
ldap_dn2ufn ldap_err2str
ldap_errno ldap_error
ldap_explode_dn ldap_first_attribute
ldap_first_entry ldap_first_reference
ldap_free_result ldap_get_attributes
ldap_get_dn ldap_get_entries
ldap_get_option ldap_get_values
ldap_get_values_len ldap_list
ldap_mod_add ldap_mod_del
ldap_mod_replace ldap_modify
ldap_next_attribute ldap_next_entry
ldap_next_reference ldap_parse_reference
ldap_parse_result ldap_read
ldap_rename ldap_search
ldap_set_option ldap_set_rebind_proc
ldap_sort ldap_start_tls
ldap_t61_to_8859 ldap_unbind
leak levenshtein
link linkinfo list
localeconv localtime
log log10 log1p
long2ip lstat ltrim
mail mailparse_determine_best_xfer_encoding
mailparse_msg_create mailparse_msg_extract_part
mailparse_msg_extract_part_file
mailparse_msg_free mailparse_msg_get_part
mailparse_msg_get_part_data
mailparse_msg_get_structure
mailparse_msg_parse mailparse_msg_parse_file
mailparse_rfc822_parse_addresses
mailparse_stream_encode mailparse_uudecode_all
max mb_convert_encoding
mb_convert_kana mb_convert_variables
mb_decode_mimeheader mb_decode_numericentity
mb_detect_encoding mb_detect_order
mb_encode_mimeheader mb_encode_numericentity
mb_get_info mb_http_input
mb_http_output mb_internal_encoding
mb_language mb_output_handler
mb_parse_str mb_preferred_mime_name
mb_send_mail mb_strcut
mb_strimwidth mb_strlen
mb_strpos mb_strrpos
mb_strwidth mb_substitute_character
mb_substr mcal_append_event
mcal_close mcal_create_calendar
mcal_date_compare mcal_date_valid
Циклы while
это простейшие циклы PHP. Они ведут себя, как их аналоги из C.
Вот базовая
форма оператора while:
Значение оператора
while просто как 3 (три) рубля. Он говорит PHP, что нужно неоднократно
выполнять вложенный оператор (-ы), пока выражение expr вычисляется в
TRUE. Значение выражения проверяется каждый раз в начале цикла,
поэтому, если это значение изменилось при выполнении вложенного оператора (-ов),
выполнение не остановится до конца данной итерации (каждый раз, когда PHP выполняет
все операторы цикла, называется одной итерацией цикла). Иногда, если выражение
expr вычисляется в FALSE в самом начале цикла, вложенный
оператор (-ы) может быть не выполнен ни разу.
Как и в операторе if,
вы можете создавать блок из операторов внутри цикла while с помощью фигурных
скобок {} или используя альтернативный синтаксис:
while (expr): statement ... endwhile; |
Следующие
примеры идентичны и оба печатают числа от 1 до 10:
/* пример 1 */ $i = 1; while ($i <= 10) { print $i++; /* будет
печататься значение $i до инкремента (пост-инкремент) */ } /* пример 2 */ $i =
1; while ($i <= 10): print $i; $i++; endwhile; |