Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Отладка

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1] 

> Описание: Урок о том, что если программа работает не так, как ее просят
Champion Супермодератор
Отправлено: 17 Марта, 2010 - 10:15:06
Post Id



Активный участник


Покинул форум
Сообщений всего: 4350
Дата рег-ции: Авг. 2008  
Откуда: Москва


Помог: 57 раз(а)




Отладка - самая важная способность программиста.

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

Представьте себе ситуацию: в туалете перегорела лампочка, вы вкручиваете новую, но светлее не становится. В темноте вы не попадаете туда, куда хотелось бы и идете искать помощи в решении проблемы в интернете. И вот на форуме, к примеру, в сообществе людей с нарушенной координацией появляется тема "Не могу попасть в унитаз! Помогите отмыть стены!". Думаете вам помогут? Нет. Потому что вы пренебрегли отладкой и не разобрались откуда растут корни проблемы.
А ведь элементарная логика подсказывает:
- координацию обеспечивают данные, поступающие с органов осязания и вестибулярный аппарат, значит надо проверить, всё ли с ними в порядке.
- выйдя на кухню и зайдя в туалет обратно, вы обнаружите, что "ага, в глаза не поступают данные!". Но глаза работают нормально: на кухне-то всё видно.
- понятно, что проблема в освещении и надо проверить систему освещения;
- убедиться в работоспособности лампочки (вкрутить ее в стопроцентно рабочий патрон);
- убедиться, что в доме есть электричество;
- убедиться в работоспособности патрона.
Допустим, электричество есть, лампочка в другом патроне загорелась - ага, не исправен патрон. Идем на форум электриков, описываем проблему и почему мы решили, что проблема в патроне. Вас все равно заставят отладить свою прогу и разобраться, когда вы будете совместными усилиями докапываться до причины проблем.

Это и есть отладка. И отладка программных продуктов по сути ничем от этой истории не отличается. И когда вы ей пренебрегаете, вы задаете вопросы, которые по своей сути есть ровно то же, что приведено выше. И не нужно думать, что раз прога компилится, то работа почти сделана. Наоборот, самое интересное только начинается. И всё, что нужно делать, выполняя отладку, - это просто следовать элементарной логике!

Итак, как следует действовать, если поведение программы отличается от того, что вы хотели.
Очевидно, либо вы не то от нее ожидаете, либо в ней логическая ошибка. Или и то, и то. Надо ее найти, и в этом нет ничего сложного.

Допустим, неожиданный результат появляется на экране. Как это происходит? На экран выводится какая-то переменная (Или сообщение об ошибке, произошедшей при выполнении). Надо разобраться, из чего она формируется. Найти, какая ее часть формируется не правильно и повторить это действие для найденной части.
Всё! Ничего сложного в этом нет! Тем более, прога ваша, вам известно, где что и почему формируется, куда лучше, чем посторонним людям, у которых вы спрашиваете решения на форуме.
Если какая-то функция выдала ошибку, надо определить, правильно ли формируются ее аргументы. Точно таким же способом. Опять ничего сложного!
Если есть циклы - смотрите, правильно ли поставлено условие выхода. Выполняйте программу по шагам на проблеммных тестовых данных, выводите промежуточные данные на экран.
Если работаете с БД, и неудачно выполняется запрос, выведите его на экран, посмотрите, скопируйте и выполните его - увидите в чем ошибка.
Если пишете на языках, в которых можно отключить вывод ошибок или перенаправить их куда-нибудь, включите их на время отладки.

И вот теперь, когда вы убеждены, что всё правильно, и что на каком-то шаге с программой происходят аномалии, можно идти на форум (или в другое место к знающим людям) и вы сможете четко изложить суть проблемы и вам гораздо быстрее помогут и не будут называть всякими новыми неизвестными вам словами.

И еще. Текст ошибки (или предупреждения), которые выдаются на этапе компиляции и выполнения - это не какие-то заумные термины, которые известны только мега специалистам на форумах. Это обычные фразы, понятные любому человеку, который связан с программированием. Их следует читать - они не просто так выдаются. Если они написаны на непонятном языке, их можно перевести - это тоже не так сложно. Да и в поисковиках по ним можно найти много исчерпывающей информации.

Несколько полезных настроек PHP, которые надо поменять при отладке:
- error_reporting = E_ALL - фиксироваться должны все ошибки;
- display_errors = 1 - чтобы мы видели их в браузере (или на консоли)
- убрать из кода всех @.
- помнить, что если вы в скрипте выполняете что-то такое:
ini_set('display_errors',1);
error_reporting(E_ALL);
то это не поможет, если в нём есть синтексическая ошибка. Эти настройки должны быть сделаны с пом. php.ini или .htaccess.
 
 Top
Ch_chov
Отправлено: 19 Марта, 2010 - 16:13:48
Post Id



Постоянный участник


Покинул форум
Сообщений всего: 2121
Дата рег-ции: Июль 2008  
Откуда: из города


Помог: 90 раз(а)




Несколько ссылок на полезные инструменты для отладки PHP:
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
1. DumPHPer
Улучшенная замена var_dump.

2. Хакерская консоль
Отладочная консоль.

3. Krumo
Замена для print_r и var_dump и еще несколько полезных для отладки функций.

4 FirePHP
Плагин для firefox. Полезный инструмент для отладки php кода в ajax приложениях и не только.

5. Xdebug
Полноценный отладчик для PHP.
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
(Добавление)
P.S. Вместо E_ALL лучше пользовать E_ALL|E_STRICT, чтобы Ваши скрипты были совместимы с будущими версиями PHP.

(Отредактировано автором: 19 Марта, 2010 - 16:16:45)

 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Уроки php »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB