Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Эквивалентность двух конструкций в PHP

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование
Предыдущая тема :: Следующая тема  
Автор Сообщение
prism



Зарегистрирован: 15.05.2005
Сообщения: 5

СообщениеДобавлено: Вс Май 15 2005 17:41    Заголовок сообщения: Эквивалентность двух конструкций в PHP Ответить с цитатой

Всегда ли можно заменить первую конструкцию на вторую?
Код:

# 1
if (isset($x) && $x) {
  /* ... */
} else {
  /* ... */
}
# 2
if (@$x) {
  /* ... */
} else {
  /* ... */
}

Если да, то насколько это безопасно, переносимо и так далее, т.е. полностью ли они эквивалентны?
Проверял в php 4.3.10.10 (денвер, дефолтные настройки), вроде разницы нет.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
trustno1



Зарегистрирован: 09.02.2005
Сообщения: 17

СообщениеДобавлено: Пн Май 16 2005 07:20    Заголовок сообщения: Re: Эквивалентность двух конструкций в PHP Ответить с цитатой

prism писал(а):
Всегда ли можно заменить первую конструкцию на вторую?
Код:

# 1
if (isset($x) && $x) {
  /* ... */
} else {
  /* ... */
}
# 2
if (@$x) {
  /* ... */
} else {
  /* ... */
}

Если да, то насколько это безопасно, переносимо и так далее, т.е. полностью ли они эквивалентны?
Проверял в php 4.3.10.10 (денвер, дефолтные настройки), вроде разницы нет.


с точки зрения кода абсолютно не эквивалентны.
В первой ты проверяшь, существует ли переменная $x, а во второй нет. И если б не собака, то в лог полез бы соответствующий notice при обращении к не заданной $x.
В общем, первый вариант мне кажется правильней
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
prism



Зарегистрирован: 15.05.2005
Сообщения: 5

СообщениеДобавлено: Пн Май 16 2005 18:53    Заголовок сообщения: Ответить с цитатой

Цитата:
В первой ты проверяшь, существует ли переменная $x, а во второй нет. И если б не собака, то в лог полез бы соответствующий notice при обращении к не заданной $x.

Так в первом случае эта проверка и нужна только для того, чтобы избежать notice`а, а во втором мы замечание просто игнорируем.
Цитата:
В общем, первый вариант мне кажется правильней

А можно пример, когда надо делать именно так, а не иначе?
Имхо второй вариант компактее и (имхо опять же) код от этого нагляднее и проще. В общем какие "за" и "против"?
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
trustno1



Зарегистрирован: 09.02.2005
Сообщения: 17

СообщениеДобавлено: Пн Май 16 2005 20:03    Заголовок сообщения: Ответить с цитатой

prism писал(а):
Цитата:
В первой ты проверяшь, существует ли переменная $x, а во второй нет. И если б не собака, то в лог полез бы соответствующий notice при обращении к не заданной $x.

Так в первом случае эта проверка и нужна только для того, чтобы избежать notice`а, а во втором мы замечание просто игнорируем.
Цитата:
В общем, первый вариант мне кажется правильней

А можно пример, когда надо делать именно так, а не иначе?
Имхо второй вариант компактее и (имхо опять же) код от этого нагляднее и проще. В общем какие "за" и "против"?


неправильно самостоятельно вырубать нотисы, они не для того пишутся. А если в последующих версиях PHP обращение к незаданной переменной будет вызывать не нотис, а fatal error, будешь код перелопачивать? Smile
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
prism



Зарегистрирован: 15.05.2005
Сообщения: 5

СообщениеДобавлено: Вт Май 17 2005 00:36    Заголовок сообщения: Ответить с цитатой

Цитата:
неправильно самостоятельно вырубать нотисы, они не для того пишутся

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

Цитата:
если в последующих версиях PHP обращение к незаданной переменной будет вызывать не нотис, а fatal error

Ой, сильно как загнул.

Цитата:
будешь код перелопачивать?

Код:

perl -pe "s#@(\$\w+)#isset ($1) && $1#g;" *.php

Немного помогает :)

В целом ты меня убедил, что первый вариант все таки лучше второго, но не настолько, чтобы вторым совсем пренебрегать. Если же есть более весомые аргументы, только буду рад услышать.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
prism



Зарегистрирован: 15.05.2005
Сообщения: 5

СообщениеДобавлено: Ср Май 18 2005 13:47    Заголовок сообщения: Ответить с цитатой

Я - валенок:
Код:

if (empty($x)) {
  echo '$x is either 0, empty, or not set at all'; # :-)
}
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...