gifts2017

Динамическое изменение переменных во время отладки.

Опубликовал Валерий (Walther_008) в раздел Программирование - Практика программирования

Во многих языках программирования есть такая фича - во время отладки "на лету" можно поменять значение переменной. В 1С почему-то не предусмотрено в штатном режиме. Это легко обойти

На самом деле идея, я так подозреваю, не новая, так что, сорри, если повторяюсь Cool

А заключается она в следующем. Есть такой замечательный оператор - Выполнить().

Создаём обработку, в которой пишем экспортную функцию, которая возвращает нам что-то (на самом деле неважно что):

//************************************************************

Функция ВыполнитьКод(ТекстКода, П1 = "", П2 = "", П3 = "") Экспорт
    
    Попытка
        Выполнить(ТекстКода);
    Исключение
        Возврат ОписаниеОшибки()
    КонецПопытки;
    
    Возврат Истина;
    
КонецФункции

//************************************************************

И помимо всего прочего, выполняет текст кода, который мы ей передали.

 

Теперь во время отладки, вызывая "Вычислить выражение...", меняем значения переменных "на лету".

Например, если во время выполнения следубщего участка кода:

 

Перем1 = 1;

Перем2 = 3;

Сообщить(Перем1 + Перем2);

 

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

ВнешниеОбработки.Создать("D:\ВыполнитьКод.epf").ВыполнитьКод("П1 = 2", Перем2)

 

В результате в окне сообщения у нас появится "3" вместо "4".

Для удобства можно эту функцию написать в модуле приложения.

 

У этой фичи есть еще одна полезная штука - можно прерывать выполнение каких-нибудь зациклившихся веток кода или просто какой-нибудь огромный цикл без перезапуска отладки. Для этого нужно присвоить какой-нибудь переменной некорректное значение. Например, агрегатный объект заменить на число или строку, тогда при обращении к полю агрегатного объекта 1Ска вывалится с сообщением об ошибке.

Скачать файлы

Наименование Файл Версия Размер
ВыполнитьКод.epf 90
.epf 4,25Kb
21.07.11
90
.epf 4,25Kb Скачать

См. также

Подписаться Добавить вознаграждение

Комментарии

1. Александр Медведев (anig99) 21.07.11 16:49
http://www.kb.mista.ru/article.php?id=105

а ещё подключаемые обработки (печатные формы и т.д.) можно отлаживать если в начало обработки поставить Попытка Исключение с заведомо ошибочной командной, а в конфигураторе включить Остановка на ошибке. И при вызове обработки конфигуратор сам откроет временный файл (а именно через них 1с открывает подключаемые обработки).
Хотя способ с формой - лучше.
2. Роман Романов (romansun) 21.07.11 19:10
(1)
лучше просто Ф11 нажимать на строке, где идет вызов внешней обработки. Сразу переместимся в код временного файла. И попытки не нужны.

Хотя способ с формой - лучше(с)


Я бы еще написал статью /"Динамическое" изменение переменных во время отладки/

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

Дык переменные так динамически меняются, что пол-офиса собирается посмотреть почему в коде написано одно, а в табло по точке останова - совсем другое :D
3. Игорь Исхаков (Ish_2) 23.07.11 18:24
(1) У Гения -то тема и полнее и интереснее.
4. Сергей Старых (tormozit) 24.07.11 10:04
В инструментах разработчика есть более удобные функции, предложенные Гением 1С.
http://infostart.ru/public/15126/

_(Перем1, СтрокаВыражения) - присваивает параметру Перем1 вычисленное значение параметра СтрокаВыражения
Например _(Построитель.Текст, "ВЫбрать * Из Константы").
Этой функцией во время паузы в отладчике я пользовался уже больше тысячи раз.

ДУ(СтрокаВыражения, П1=, П2=, П3=,...) - выполяет код из параметра СтрокаВыражения, где могут применяться параметры П1, П2, П3,...
Например ДУ("П1.Текст = П2", Построитель, "ВЫбрать * Из Константы").

Добавил описание этих функций в описание подсистемы.
5. Игорь Исхаков (Ish_2) 24.07.11 10:55
(4) Ага, посмотрел мельком тему.
Судя по всему , работа содержит решения , которые полезны при изучении платформы.
Понятно , что работа немалая и откликов много.

Меня же волнует один вопрос :
кто же будет использовать такое решение в практической работе ?
Сам я - Боже упаси.
Поспрашивал знакомых на предмет использования сторонних продуктов (не ИТС) при разработке - получил такой же ответ.
Я чего-то не понимаю ? Не там и не у тех спрашивал ?
6. Сергей Старых (tormozit) 24.07.11 11:10
(5) Ну похоже, что какие то 700 человек используют судя по рейтингу)
7. Игорь Исхаков (Ish_2) 24.07.11 11:12
8. Артур Аюханов (artbear) 24.07.11 14:13
(5) Не ожидал от тебя услышать подобное :(
ИМХО хороший разработчик как раз ДОВОЛЬНО ЧАСТО юзает сторонние продукты при разработке.
А уж система ИР (4 как раз ее автор) не нуждается ни в каких рекомендациях :(
хотя неверующие могут посмотреть количество плюсов и количество скачиваний.
ЗЫ ОФФ поменяй знакомых :)
9. Игорь Исхаков (Ish_2) 24.07.11 14:22
(8) Менять "знакомых" - слишком хлопотно.
Но с удовольствием сообщу : "Вам, ребята, подучиться бы чуток.. ".
Гарантирую , эта шутка им понравится.
10. Игорь Исхаков (Ish_2) 24.07.11 14:42
(8) Впрочем , ты наверно не понял меня.
Скачать обработку с ИС для решения какой-то текущей пользовательской задачи ("заткнуть дырку" попросту ) - это всегда- пожалуйста.
Использовать же чужой код в своей разработке - это совсем другое .
Подсмотреть какие-то ходы или идеи в чужой разработке - тоже всегда-пожалуйста.
Но вот так : взять и объединить свою разрабатываемую конфигурацию с чужой поставкой...

Люди разные , конечно, и всякие чудеса случаются - не отрицаю.
Но остаюсь при своём сромном мнении : Ерунда ! Хоть 7 000 плюсов и 70 000 скачиваний.
Понятно , что здесь ничего личного - здесь только принцип.
11. Роман Романов (romansun) 24.07.11 15:40
(10)
не, ну зачем обязательно объединять-то? Это просто набор инструментов, помогающих в работе.

Я, к примеру, тоже ничего такого не объединяю со своей рабочей базой. Но использую разные консоли, анализаторы какие-нить, какие-то обработки переносов xml-ные и пр, и пр. Использую методики и приёмы из таких вот "инструментальных пакетов".


И коллеги-знакомые - кто как. В зависимости от решаемых задач, уровня подготовки и - главное - соответствующей черты характера :). Есть люди, которые буквально балдеют от всяких комбайнов, а есть те, кому достаточно ИТС-ной консоли запросов и всё. Причем уровень и тех и других весьма высок и решают задачи они сопоставимо быстро и качественно.

Т.е. кому как удобно, кто как привык и кто какую "производственную" методику себе выбирает.
12. Виктор Клименко (dicwork) 13.12.11 20:26
А под 1С 7.7 так можно? До 1С работал с Clipper, потом с Delphi. Там отладчики были довольно мощные. В 1С не хватает в отладчике возможностей.
13. Сергей Старых (tormozit) 16.12.11 08:54
(10)

Про встраивание подсистемы в конфигурацию.

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

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

Можно использовать подсистему только на тестовых базах, а на рабочую объединением натягивать конфигурацию без подсистемы.
14. Dmitiry (ndacoder) 16.12.11 23:46
(13) если работа с конфигурацией один, то иногда встраиваю (4)
а вот если работа в команде то только внешние обработки( ибо хранилище)
15. Сергей Старых (tormozit) 16.12.11 23:50
(14) А как вы решаете, добавлять ли в хранилище какую то скажем функцию или обработку, которая точно будет полезна большинству разработчиков для отладки?
16. Kostya Zhurov (It-developer) 21.01.12 13:21
Спасибо, возможно буду пользоваться
17. Владимир Чаклин (vec435) 11.03.12 12:06
динамическая отладка кода - без перезагрузки клиента http://infostart.ru/public/119661/
Walther_008; +1 Ответить
18. Илья Вильчик (TreeDogNight) 07.11.15 20:00
Теперь можно не париться с такими метадоми! В новой платформе 8.3.7 в окне вычисления выражения, появилась функция изменения значения переменной!
Прикрепленные файлы:
19. Валерий (Walther_008) 09.11.15 15:51
(18) TreeDogNight, не прошло и 5 лет ))))
Для написания сообщения необходимо авторизоваться
Прикрепить файл
Дополнительные параметры ответа