Понеділок, 22.04.2019, 00:02
Гость

Мішатронік

Автор - Кренцін Михайло

Мобільна версія | Додати у вибране  | Мій профіль | Вихід | RSS |
Меню сайту
Наше опитування
Які схеми ви любите паяти?
Всього відповідей: 5
Статистика

Онлайн всього: 1
Гостей: 1
Користувачів: 0




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


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

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

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

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

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

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

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

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

 

 

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

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

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

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

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

 

Форма входа
Пошук
Календар
«  Квітень 2019  »
ПнВтСрЧтПтСбНд
1234567
891011121314
15161718192021
22232425262728
2930
Друзі сайту
Погода у Вінниці


Єдина Країна! Единая Страна!