Асинхронная концепция программирования в «1С:Предприятие 8» или выполнение программного кода «в фоне»

Публикация № 341698 04.04.15

Разработка - Механизмы платформы 1С

#1C #Лаборатория Аксиом #axiomlab #Асинхронное программирование

Как правило, в реальных задачах оказывается недопустимым длительное выполнение обработчика события, поскольку при этом программа не может реагировать на другие события - блокируется пользовательский интерфейс.
В данной статье рассмотрены следующие вопросы:
1. Концепция асинхронного программирования
2. Фоновые задания в «1С:Предприятие 8»
3. Пример асинхронного выполнения длительных серверных операций с помощью фонового задания
4. Пример асинхронного выполнения длительных серверных операций с помощью фонового задания с использованием БСП.

Концепция асинхронного программирования

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

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

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

Как видно из графиков, коэффициент полезных интерактивных действий пользователя при синхронной модели программирования отсутствует, так как система блокирует пользовательский интерфейс, в то время как при асинхронной модели, пользователь продолжает активную работу в системе. 

 

При синхронном выполнении у приложения есть только один поток. С помощью асинхронной модели программирования вы можете запускать множество параллельных потоков и во время их выполнения реагировать на новые действия пользователя. После того как n-поток выполнен, вы отображаете результат на экран.

 

Фоновые задания в «1С:Предприятие 8»

В «1С:Предприятие 8» фоновые задания предназначены для выполнения прикладных задач асинхронно. Они могут порождать дочерние фоновые задания, например, для распараллеливания сложных вычислений по различным рабочим серверам кластера в клиент-серверном варианте работы.

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

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

 

Клиент-серверный вариант

В клиент-серверном варианте планированием выполнения заданий занимается планировщик заданий, который физически располагается в менеджере кластера.

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

Файловый вариант

Начиная с версии 8.3.3.641 платформы, разработчики значительно упростили работу с фоновыми заданиями в файловом варианте.

Раньше для автоматического выполнения заданий требовалось запускать отдельный, дополнительный сеанс «1С:Предприятия», используемый в качестве планировщика заданий. И в этом сеансе нужно было периодически выполнять метод встроенного языка ВыполнитьОбработкуЗаданий(). Такой подход был довольно громоздким, неудобным и сильно ограничивал использование фоновых и регламентных заданий в файловом варианте работы.

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

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

 

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

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

 

Пример асинхронного выполнения кода в «1С:Предприятие 8»

«Писать программы, в которых результат вызова функции приходит неизвестно когда - куда сложнее, чем обычные. Вложенные вызовы, обработка ошибок, контроль над происходящим - все усложняется», - так скажут только те, кто не умеет правильно пользоваться возможностями платформы, но не мы!

Продемонстрируем всю простоту и изящество асинхронного выполнения кода в «1С:Предприятие 8»!

Шаг 1. Создадим новую ИБ для разработки конфигурации

Шаг 2. В конфигурации добавим общий модуль «АсинхронныеОбработчики»

Почему мы добавили общий модуль? Тут все просто: для выполнения асинхронных операций в «1С:Предприяте 8» применяются фоновые задания, у которых имеется свой менеджер - «МенеджерФоновыхЗадания». У этого объекта есть метод «Выполнить», с помощью которого как раз и запускается фоновое задание.

Обратимся к синтакс-помощнику.

 

Таким образом, нам понадобится общий модуль.

 

 

Шаг 3.  В общем модуле «АиснхронныеОбработчики» добавим экспортную процедуру НашаДлительнаяОперация()

Процедура НашаДлительнаяОперация(Длительность) Экспорт
	// Имитация продолжительного действия (Длительность сек.).
		ДатаНачалаОперации = ТекущаяДата();
		Пока ТекущаяДата() - ДатаНачалаОперации < Длительность Цикл
	КонецЦикла;
КонецПроцедуры

Шаг 4. Добавляем в конфигурацию обработку «АсинхроннаяКонцепцияПрограммирования» (можно создать внешнюю обработку)

 

На форму добавляем один реквизит:

- Длительность (Число)

и две команды

- ВыполнитьДлительнуюОперацию;

- ВыполнитьДлительнуюОперациюАсинхронно.

Шаг 5.  Согласно синтакс-помощнику заполняем модуль формы

&НаКлиенте
Процедура ВыполнитьДлительнуюОперацию(Команда)
	ВыполнитьДлительнуюОперациюНаСервере();
КонецПроцедуры

&НаСервере
Процедура ВыполнитьДлительнуюОперациюНаСервере()
	АсинхронныеОбработчики.НашаДлительнаяОперация(Длительность);
КонецПроцедуры

&НаКлиенте
Процедура ВыполнитьДлительнуюОперациюАсинхронно(Команда)
	ВыполнитьДлительнуюОперациюАсинхронноНаСервере();
КонецПроцедуры

&НаСервере
Процедура ВыполнитьДлительнуюОперациюАсинхронноНаСервере()

	Параметры = Новый Массив;
	Параметры.Добавить(Длительность);
	
	ФоновыеЗадания.Выполнить("АсинхронныеОбработчики.НашаДлительнаяОперация", 
		Параметры, Новый УникальныйИдентификатор, "Пример асинхронной концепции программирования");	
	
КонецПроцедуры
 

Шаг 6. Запускаем и проверяем!

Результат:

- если мы нажимаем на кнопку «Выполнить длительную операцию», то пользовательский интерфейс на «Длительность» секунд блокируется;

- если мы нажимаем на кнопку «Выполнить длительную операцию асинхронно», то пользовательский интерфейс не блокируется, а программный код выполняется параллельно.

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

 

Отладить программный код, который выполняется в «фоне» мы можем, если в параметрах отладки установим соответствующее свойство.

 

Пример асинхронного выполнения кода в «1С:Предприятие 8» с использование БСП

Пример реализации асинхронной концепции программирования в «1С:Предприятие 8» в БСП рассмотрим на примере обработки «Текущие дела».

 

 

Логика следующая: во время запуска программы инициализируется рабочая область начальной страницы, куда можно вывести форму обработки «Текущие дела». Эта форма заполняется текущими делами пользователя, а чтобы ее заполнить необходимо время. Если бы у разработчиков не было возможности асинхронно выполнять код, то на все время заполнения формы обработки пользовательский интерфейс был бы заблокирован!

 

Проанализируем программный код формы.

Событие формы «ПриСозданииНаСервере» вызывает процедуру «ЗапуститьФоновоеЗадание» - это то, что нам и нужно. 

 

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

 

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

И Что же дальше? А дальше нам необходимо отловить момент выполнения задания.

Для этого разработчики применяют метод ПодключитьОбработчикОжидания(<ИмяПроцедуры>, <Интервал>, <Однократно>).

В подключаемой процедуре Подключаемый_ПроверитьВыполнениеЗадания() разработчики вызывают функцию ЗаданиеВыполнено(ИдентификаторЗадания)


Данная функция по идентификатору проверяет выполнения фонового задания.

Необходимо отметить, что в БСП разработаны общие модули поддержки работы длительных серверных операций.

 

Таким образом, асинхронная концепция программирования в «1С:Предприятие 8» незначительно увеличивает трудоемкость решения задач для разработчика, но заметно улучшает функциональность программы с точки зрения пользователя.

Специальные предложения

Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. recon 120 04.04.15 13:08 Сейчас в теме
Отличная статья! Но у фоновых заданий есть и подводные камни, связанные с ошибками (или фичами?) платформы. В частности 1С не контролирует расход процессорного времени при выполнении фонового задания и десяток фоновых заданий, выполняющих какой то "тяжелый" расчет, могут запросто положить сервер на лопатки. Выход - перенос менеджера фоновых заданий на другой сервер (доступно с платформы 8.3), а значит фоновые задания будут выполняться на выделенном сервере. Возможно в новых релизах что то поменялось
Ну и периодически на сервере может зависнуть процесс фонового задания. 1С хоть и реализовала метод аварийного завершения фонового процесса, но на самом деле он всего лишь посылает команду завершения, не завершая принудительно процесс. Приходится контролировать зависшие процессы периодически через консоль сервера.
RustIG; maljaev; +2 Ответить
2. Infactum 309 05.04.15 12:05 Сейчас в теме
Конечно на безрыбье и рак рыба, но называть это все асинхронным программированием будет не совсем корректно. Для реализации полноценного асинхронного программирования нужна либо нормальная работа с обратными вызовами, либо Promise/Deferred. Очень рекомендую по смотреть в сторону node.js + callback/promise или C# + async/await, чтобы понять, как именно все это должно работать. По факту сейчас за 1С просто стыдно :(
PhoenixAOD; G_101343795907160391674; pqt; vpndos; it@contlog.ru; vvp117; boln; Gang031; ybatiaev; johny1987; It-developer; Drfreeman; sigmov; sbcode; brr; 7OH; Kuzja_R; cefew; nSpirit2; perpleks; Жолтокнижниг; +21 4 Ответить
3. pumbaE 05.04.15 13:35 Сейчас в теме
(2) Ну так используйте Показатьоповещение, бесконечный loop и подключитьобработчик ожидания. Превращать в callback ад, код ради "стыдно" не имеет смысла.
В том же питоне, попытались не реализовывать сразу весь ужас callback и не превращать в код в спагети.
Михаська; RustIG; +2 Ответить
4. Infactum 309 05.04.15 14:00 Сейчас в теме
(3) pumbaE, в питоне есть asyncio. Я на callback модели и не настаивал, специально привел несколько примеров.
И к слову о JS и "callback hell" - это проблема исключительно начинающих программистов. Использование библиотек типа node-async или отказ от обратных вызовов в пользу обещаний решает все это на корню.
5. pumbaE 05.04.15 14:21 Сейчас в теме
(4) в типовой поставке 1с нет ни тестирования, ни документации кода, как получить работающий код при малейшем изменении одного из обещаний?
Уже сейчас можно с трудом отладить модель подписок в БСП, пока инструментов нет для нормальной поддержки кода.
9. nSpirit2 09.04.15 12:20 Сейчас в теме
Много много букав совсем не о чем :)
К сожалению пока вся концепция 1с завязана на том что клиентские приложение само отслеживает выполнилось фоновое задание или нет.
Обилие описания плюсов о том что пользовательский интерфейс не блокируется по большей части преувеличение удобности этого для пользователя. Мы не завешиваем окно пользователя но не факт ему нужно работать пока не закончиться длительная операция. Отслеживание работы пользователя по большей части показывает, что выполнение отчета в фоне не как не помогает пользователю работать так как он ожидает результат. Для моей базы это примерно 70 процентов. Так что речь о оставлении возможности интерактивной работы пользователя по большей части надумана. Так как любая длительная операция которая необходима пользователю по большей части не требует не блокировки интерфейса это скорее удобность работы так как пользователи по большей части не многозначны и ожидают результата своих действий перед выполнением следующей задачи. Основная удобность всех фоновых процессов к сожалению сводиться к возможности незаметно для пользователя обновлять часть видимой ему информации. Либо перенос в них задач результат выполнения которых пользователь не ожидает.

Что относительно описания в БСП. Я думал будет больше функции из модулей <color #FF6347>ДлительныеОперации</>*.
Такие функции как СообщитьПрогресс и ПрочитатьПрогресс к сожалению не нашли отражения в примере хотя именно для длительных операций они весьма интересны. Что интересно. C помощью него можно выполнять не только экспотрные процедуры но и команды отчетов и обработок что значительно удобней чем строковых адресов в функции.

Простите но статья по большей части не о чем. Ждем детального продолжения.

(5) pumbaE, То что вы по прежнему кушайте кактус совсем не значит что другие тоже его едят. Есть и инструменты для тестирования и инструменты для документирования. А относительно спагети. Вы пробуйте написать паралельно вычисление на фоновых заданиях вам callback счастьем покажется.

(4) Infactum, К слову а JS в 1с со всей этой концепцией фоновых вычислений по большей части не хватает возможности помещения в переменные ссылок на функции для дальнейшего их использования.
ybatiaev; Chai Nic; softgarant; Gang031; alexey.kutya; +5 1 Ответить
15. SMART1C 744 09.04.15 13:01 Сейчас в теме
(9) nSpirit2, благодарю за детальный комментарий!
По пунктам,
п.1
Простите но статья по большей части не о чем.

Нет предела совершенству - будем стараться, будем работать над собой!

п.2
Отслеживание работы пользователя по большей части показывает, что выполнение отчета в фоне не как не помогает пользователю работать так как он ожидает результат. Для моей базы это примерно 70 процентов.

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

п.3
Что относительно описания в БСП. Я думал будет больше функции из модулей <color #FF6347>ДлительныеОперации</>*

Главной задачей статьи является попытка передать КОНЦЕПЦИЮ асинхронного программирования, но с небольшими и понятными примерами в "1С:Предприятие".

Ждем детального продолжения.

Если тема заинтересует достаточное количество специалистов, то продолжение следует!
Alf06; zadoy; Gang031; RustIG; +4 Ответить
32. Dipod 108 24.08.18 13:45 Сейчас в теме
(9) В случае серверной базы с помощью фоновых заданий можно писать асинхронные обработки, которые распараллеливают выполнение алгоритма на несколько потоков.

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

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

Если 4 миллиона элементов разбить на диапазоны по миллиону и запустить создание этих элементов в 4-х фоновых заданиях, то получаем загрузку проца в 100% и ускорение выполнения задачи в 4 раза (если не упремся в другие аппаратные ограничения, например в скорость записи на диск).
33. Denanhel 13.09.18 16:47 Сейчас в теме
(32)
Требуется создать очень много элементов справочника в базе, например, 4 миллиона.
Поделюсь своим печальным опытом... На выходе получаем "Конфликт блокировок при выполнениии транзакций" Для записи в БД такой подход очень бы не советовал использовать..
Михаська; RustIG; +2 Ответить
34. Dipod 108 14.09.18 11:37 Сейчас в теме
(33) Согласен, что есть вероятность конфликта блокировок, но я лично пробовал так создавать элементы и даже создавать и проводить документы, и конфликта блокировок не наблюдал. Но это еще не доказывает, что конфликта никогда не произойдет :-)
35. Denanhel 15.09.18 09:04 Сейчас в теме
(34) Всё зависит от объёма данных, записываемых в базу и количества потоков. Мне нужно было записывать от 10 до 100 тысяч товаров в самописную конфигурацию раз в час. К тому же платформа 8.2. Блокировки не управляемые. Пробовал в 24 потока организовать (процессор позволяет). - тьма блокировок. Разложил на 4 потока. Блокировки пропали. Вот только скорость соответственно в 6 раз упала. Ну соответственно нужно искать компромисс... А так согласен плюсом идёт еще и то что можно сохранить адрес хранилища в локальной переменной и когда нужно получить ответ. Я допустим запускаю создание товаров в фоне, а в то же время загружаю справочник свойств этих товаров в отдельном потоке, а затем уже согласно полученным данным имея загруженные товары и свойства собираю регистр значений свойств. Получается гораздо быстрее чем делать всё поочередно.
garibyanlev; Dipod; +2 Ответить
36. Dipod 108 17.09.18 09:50 Сейчас в теме
(35)Да, я экспериментировал на платформе 8.3 и всего в 4 потока :-)
6. klinval 330 06.04.15 09:21 Сейчас в теме
&НаСервере
Процедура ВыполнитьДлительнуюОперациюАсинхронноНаСервере()

    Параметры = Новый Массив;
    Параметры.Добавить();
    
    ФоновыеЗадания.Выполнить("АсинхронныеОбработчики.НашаДлительнаяОперация", 
        Параметры, Новый УникальныйИдентификатор, "Пример асинхронной концепции программирования");    
    
КонецПроцедуры
Показать

Вы случайно не забыли в параметрах передать длительность?
ybatiaev; SMART1C; +2 Ответить
7. SMART1C 744 06.04.15 09:45 Сейчас в теме
(6) klinval, Спасибо! Подправил.
38. ybatiaev 58 19.09.19 15:06 Сейчас в теме
(6) Ещё бы не мешало перед запуском фонового задания проверять уже запущенные фоновые задания. Некоторые можно плодить, а некоторые нет. К примеру, одно не закончилось, а ваша программа по функции ПодключитьОбработчикОжидания запускает точно такой же. Один не закончился из-за загрузки системы, второй запустился и ещё больше нагрузил систему...
Мой пример с проверкой для разного вида фоновых дажаний
//головная функция запуска фоновых заданий с оценкой
Процедура ПроверитьЗапуститьФоновоеЗадание(Наименование, НаименованиеПроцедуры, Параметры_, ЗапуститьБезПроверки=Ложь) Экспорт
	//ФоновыеЗадания.ПолучитьФоновыеЗадания() // тут все, без отбора
	Отбор = новый структура("Состояние, Наименование", СостояниеФоновогоЗадания.Активно, Наименование);
	КоличествоФЗ = ФоновыеЗадания.ПолучитьФоновыеЗадания(Отбор).Количество();
	ЗапускатьСледующееФоновоеЗадание = ?(КоличествоФЗ > 0, Ложь, Истина);

	Если ЗапускатьСледующееФоновоеЗадание или ЗапуститьБезПроверки Тогда
		фз = ФоновыеЗадания.Выполнить("АсинхронныеОбработчики."+НаименованиеПроцедуры, Параметры_, Новый УникальныйИдентификатор, Наименование);    
	КонецЕсли;
КонецПроцедуры
Показать
8. RustIG 1654 09.04.15 12:07 Сейчас в теме
(0) проект интересный!

....а как мы жили раньше без этого?!.....
я учил бухгалтеров так: запускаете один сеанс бухгалтерии, запускаете формирование ОСВ,
открываете второй сеанс бухгалтерии и продолжаете работу во втором сеансе....

задачи другого рода, когда бухгалтер нажимает на кнопку, и следующий процесс чересчур длительный я решал таким образом: например отправку счета на оплату в БП 1.6 - создал регистр сведений "Очередь отправки", куда записывалось электронное письмо. В параллельном сеансе под пользователем "Электронка" все собранные письма начинали отправляться по очереди, не нагружая сеанс 1С у бухгалтера...

ybatiaev; +1 Ответить
10. pumbaE 09.04.15 12:24 Сейчас в теме
Есть и инструменты для тестирования и инструменты для документирования
поделитесь хотя-бы названиями.
11. nSpirit2 09.04.15 12:35 Сейчас в теме
(10) pumbaE,
https://github.com/xDrivenDevelopment/xUnitFor1C ну для тестирования вот вам ссылка. Посмотрите) А то куда ведет ссылка ответ на вопрос про документацию.
shalimski; JohnyDeath; kuntashov; Pr-Mex; lustin; +5 Ответить
12. pumbaE 09.04.15 12:40 Сейчас в теме
(11) дайте догадаюсь документацию в wiki?
13. nSpirit2 09.04.15 12:46 Сейчас в теме
(12) pumbaE, Ну в моем случае это git + некоторые скрипты для извлечения комментариев из хода.
14. pumbaE 09.04.15 12:54 Сейчас в теме
(13) не поделитесь скриптами по документированию и опытом работы с xUnitfor1c?
Какие режимы работы тестируете (управляемые формы, обычные формы)?
Используете ли 8.3.5 кнопку нажималку для тестового случая?
Как часто запускаете тесты? Автоматизировали ли CI в виде какого-либо сервиса сборки? Автоматизировали ли CD для обновления production базы?
Какие затраты на написание тестов были вначале, какие сейчас?

Мне было-бы очень интересно услышать ответы на эти вопросы.
troubleshooter; pbazeliuk; RustIG; +3 Ответить
27. nSpirit2 11.04.15 10:27 Сейчас в теме
(14) pumbaE, xUnitfor1c познакомились примерно в июле 2014. Случайно наткнулся в Гугле. С тем учетом что наша компания по факту занимается разработкой и продажей ПО которое сами и пишем (не 1с ). Cсобственно к разработке на 1с для внутренних нужд применяются те же требования. Используем для CI что то отдаленно напоминающее TeamCity. С возможностью автоматического тестирования и выкладки при условии динамического обновления. В части тестов интерфейсов после полного перехода на Управляемые формы в конце июня используем xUnitfor1c.

Ну относительно затрат сложный вопрос. С начала было тяжело были специальные люди которые писали тесты для интерфейсов. Но вообщем оно однозначно того стоит. Теперь в части маленьких изменений используем TDD.

Относительно документирования используем большую часть возможностей которые дает Git. В текущей ситуации пытаемся понять насколько возможно использовать стандартный git-flow для 1с не храня бинарники *.cf на всякий случай.
Это если совсем коротко.
28. artbear 1428 12.05.15 17:13 Сейчас в теме
Что-то я эту тему пропустил.
И упоминание "моей прелести" xUnitFor1C также :)

(27) А используете именно Gui/интерфейсные тесты в xUnitFor1C (через кнопко-нажималку) или обычные тесты в УФ для xUnitFor1C также юзаете?
19. lustin 10.04.15 13:00 Сейчас в теме
16. lustin 10.04.15 12:27 Сейчас в теме
(11) nSpirit2, ;-) сделал мой день ;-)
CSiER; nofx; pbazeliuk; kuntashov; +4 Ответить
18. nSpirit2 10.04.15 12:52 Сейчас в теме
(16) lustin, Нуу я все таки надеюсь что эта часть будет сильно популярна в среде 1С разработчиков что бы было меньше объяснять новым разработчикам.
(17) lustin, Я описания на github прочитал. Идея конечно отличная не подскажите к быстро будет развиваться функциональность. К несчастью функционал БСП она пока не покрывает есть ли план развития ?
20. lustin 10.04.15 13:13 Сейчас в теме
(18) nSpirit2

1. по развитию надо спрашивать у https://plus.google.com/+ЕвгенийПавлюк - не могу определенно сказать какие у него дальнейшие планы. Сейчас насколько я понимаю была основная цель - поделиться подсистемой.

2.
что бы было меньше объяснять новым разработчикам.
тут вот какое дело, только без обид - потому что это было весело...

мы также поступаем - советуем всем использовать подходы и инструментарий. Тот же xUnit или https://github.com/silverbulleters/vanessa-behavoir, но блин... вы дали ссылку на инструментарий одному из авторов ;-) https://github.com/pumbaEO
21. nSpirit2 10.04.15 13:19 Сейчас в теме
(20) Неожиданные высказывания для разработчика :D Теперь и я ржу :D
22. pumbaE 10.04.15 14:39 Сейчас в теме
(21) ну основное мое замечание касалось "типовой"(поставки, типового функционала от 1с).
24. JohnyDeath 300 10.04.15 17:29 Сейчас в теме
(11) Весело наблюдать за тем, как советуют поучиться инструменту одному из основных разработчиков этого инструмента )))
wazup666; ybatiaev; u_n_k_n_o_w_n; nofx; artbear; tormozit; kuntashov; Evil Beaver; karapuzzzz; +9 Ответить
25. Evil Beaver 7830 10.04.15 18:11 Сейчас в теме
(24) JohnyDeath, Ну это же круто, это признание!
JohnyDeath; kuntashov; +2 Ответить
26. pumbaE 10.04.15 19:34 Сейчас в теме
(25), (24), (16) тролли. Я, наоборот, рад тому, что кто-то другой знает и использует данный инструмент.

p.s.:
Мне все таки интересен ответ на (14) вопрос, хоть частичный.
h00k; artbear; nSpirit2; JohnyDeath; kuntashov; +5 Ответить
17. lustin 10.04.15 12:43 Сейчас в теме
(0) Ну это всё конечно хорошо, но раз уж тема актуальна и поднята, но это не наш метод - нет у нас доверия стабильности БСП, потому что нет тестов на эту функциональность, как верно заметили в (5)

А что же тогда наш метод ? Вот вам пример вчера публикации на Хабре:

1. Исходная публикация http://habrahabr.ru/post/255387/
2. Репозиторий на github https://github.com/wizi4d/TaskManagerFor1C
3. Кстати *внезапно* подсистема накрыта тестами https://github.com/wizi4d/TaskManagerFor1C/tree/master/%D0%A2%D0%B5%D1%81%D­1%82%D1%8B
23. karapuzzzz 64 10.04.15 16:55 Сейчас в теме
От себя добавлю как можно передавать параметры и ловить результат.
Для начала создаем временное хранилище:
АдресВХранилище = ПоместитьВоВременноеХранилище(Неопределено);

Потом создаем массив, в который заносим адрес в хранилище и остальные параметры:
НаборПараметров = Новый Массив;
НаборПараметров.Добавить(АдресВХранилище);
НаборПараметров.Добавить(Параметр1);
НаборПараметров.Добавить(Параметр2);
НаборПараметров.Добавить(Параметр3);

Если идет распараллеливание задания, то создается массив заданий и массив адресов в хранилище.
В самом задании результат помещаем в хранилище:
ПоместитьВоВременноеХранилище(Результат, АдресВХранилище);

После того как словили факт окончания выполнения задания можно обработать результат. Для этого получаем результат из хранилища и делаем что хотим с этим:
Результат = ПолучитьИзВременногоХранилища(АдресВХранилище)

Valador; frkbvfnjh; a45; +3 Ответить
29. WKBAPKA 214 25.09.15 09:17 Сейчас в теме
Статья довольно таки интересная.
Для решения некоторых задач оч. даже полезная
30. kote 534 16.01.17 23:10 Сейчас в теме
Тоже делал механизм параллельной работы на фоновых заданиях..

Сейчас возникла мысль - с сообщениями можно поступить следующим образом:

Сделайте запуск фонового задания СообщениеИзФоновогоЗадания, которое будет вызываться из Вашего задания.
В параметрах - передайте Сообщение для пользователя..

В самом же задании принудительно вызывайте ошибку и выводите своё сообщение для пользователя, не прерывая первоначального задания.
31. vitonya 79 16.05.18 12:01 Сейчас в теме
1С что-то оптимизирует, городит, а в результате, программа все медленней работает. ОПТИМИЗАЦИЯ, мля!!!
Chai Nic; +1 Ответить
37. masteroll 20.06.19 19:23 Сейчас в теме
Спасибо! Отличная статья!
39. igor_1c 16 29.03.22 10:01 Сейчас в теме
в релизе 8.3.18 все поменялось. Теперь по другому- есть понятие АСИНХ и деректива ЖДАТЬ
Оставьте свое сообщение

См. также

Расширение глобального поиска 1С, или Глобальный поиск "на максималках"

Механизмы платформы 1С Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Мало кто знает, что поле "Глобального поиска" в 1С можно доработать. Добавить свои варианты поиска, кнопочки в результатах и даже целые пользовательские меню.

27.03.2023    2686    SeiOkami    9    

98

Версионирование объектов VS История данных

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Давайте разберемся в механизме «История данных» и поэкспериментируем для наглядности. Сравним «Версионирование объектов» и «Историю данных».

06.03.2023    3987    dsdred    34    

108

Оператор GOTO в 1С - табу или волшебная палочка?

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

В ежедневной практике программирования на платформе 1С оператор Goto (Перейти) практически не встречается. Не удивительно, что половина специалистов даже не подозревает о существовании данного оператора. Ну, а знающим он внушает ужас, и его стараются избегать. Так что же это за редкий оператор, и для чего он нужен?

19.02.2023    5095    Dementor    72    

43

Идентификатор объекта в запросе. Вы этого хотели?

Запросы Механизмы платформы 1С Платформа 1С v8.3 Запросы Бесплатно (free)

В платформе 8.3.22 появилась возможность получать идентификатор в запросе. Лично я ждал этого давно, но по итогу ждал большего. Что не так?

12.01.2023    8839    dsdred    13    

63

Маленькие хитрости большой платформы (часть 1)

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

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

29.12.2022    3867    zeltyr    25    

40

1СПАРК РИСКИ. Сервис оценки благонадежности контрагентов. Промо

СПАРК помогает предотвратить мошенничество со стороны компаний и предпринимателей, благодаря актуальным сведениям о компаниях и системе выявления факторов риска.Сервис позволяет управлять налоговыми рисками и комплексно оценивать благонадежность контрагентов.

Практическая шпаргалка по новым возможностям языка запросов 1С

Механизмы платформы 1С Запросы Платформа 1С v8.3 Запросы Конфигурации 1cv8 Бесплатно (free)

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

21.11.2022    15137    quazare    34    

109

Асинхронное нечто, или так, как раньше!

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Все же знают, что раньше было лучше! Возврат к истокам и погружение в детали...

23.10.2022    4414    starik-2005    38    

38

О цикле обратном замолвите слово...

Механизмы платформы 1С Языки и среды Платформа 1С v8.3 Платформа 1C v8.2 Бесплатно (free)

Однажды, написав статью, расписывающую достоинства 1С, я упомянул среди недостатков - мне не хватает "обратного цикла". При этом, столкнулся с непониманием - "а зачем тебе обратный цикл". Сегодня я отвечу на этот вопрос.

08.09.2022    5480    DrAku1a    69    

30

1С и Unicode

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Разбираемся, как 1С работает с текстом и отдельными символами в контексте Unicode.

05.09.2022    3823    Irwin    30    

80

Готовые переносы данных из различных конфигураций 1C Промо

Рекомендуем готовые решения для переноса данных из различных конфигураций 1C. C техподдержкой от разработчиков и гарантией от Инфостарт.

Шпаргалка по функциям АСИНХ

Механизмы платформы 1С Платформа 1С v8.3 Россия Бесплатно (free)

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

29.07.2022    13412    zeltyr    17    

137

Экспертный кейс. История расследования одного небыстрого закрытия месяца в 1C:ERP. Пример неочевидных путей расследования в виде детективной истории

HighLoad оптимизация Механизмы платформы 1С Запросы Платформа 1С v8.3 1С:ERP Управление предприятием 2 Бесплатно (free)

В данной статье хотим рассказать об одном нашем непростом расследовании, в котором удалось собрать сразу несколько проблем на разных уровнях инфраструктуры заказчика и изначальной методологии ведения учета. Само расследование в какой-то момент стало напоминать детективную историю, с роялями в кустах, ошибками платформы, странным поведением пользователей и магическим поведением хорошо знакомых механизмов. Но мы реалисты, поэтому все проблемы были выявлены и устранены ;)

11.07.2022    5396    it-expertise    27    

56

Последовательность выполнения расширений

Механизмы платформы 1С Бесплатно (free)

Вынес в отдельную статью порядок применения нескольких расширений для одного метода

23.06.2022    3919    kuzyara    7    

55

Состав индексов с дополнительным упорядочиванием на уровне СУБД (MS SQL) при индексации реквизитов

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

В момент обсуждения с коллегами работы индексов в 1С был затронут один из вопросов, который касался темы - каким образом происходит построение индексов при индексации реквизитов у объектов 1С (конкретнее, когда свойство реквизита "Индексировать" устанавливается в "Индексировать с доп. упорядочиванием"). Ранее я всегда опирался на знания, полученные в процессе чтения официальной документации от компании 1С, опубликованной на ITS. Наши мнения в этом вопросе разошлись и, как оказалось позже, мои знания не были актуальными, в итоге было проведено некоторое исследование по данному вопросу, чтобы выяснить истину.

15.06.2022    2759    sinichenko_alex    9    

33

Динамическое обновление - это зло?

Механизмы платформы 1С Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Копнем глубже в тему "Что же такое динамическое обновление" и почему оно может привести к проблемам. И может ли?

09.05.2022    16653    Infostart    77    

227

Программы для исполнения 54-ФЗ Промо

С 01.02.2017 контрольно-кассовая техника должна отправлять электронные версии чеков оператору фискальных данных - правила установлены в 54-ФЗ ст.2 п.2. Инфостарт предлагает подборку программ, связанных с применением 54-ФЗ, ККТ и электронных чеков.

Об одной неочевидной проблеме перехода на версию платформы 8.3.20

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

При переходе на платформу 8.3.20 мы столкнулись с ошибкой "Повторяющийся псевдоним "Ссылка" Ссылка AS Ссылка,Presentation AS Presentation,Ссылка AS Ссылка" в ряде типовых конфигураций. Причём, эта проблема оказались неизвестна ни Яндексу, ни Гуглу. Путём мучительных экспериментов нам удалось найти решение. Пока я ещё не уверен, действительно это решение или обходной костыль, а настоящая проблема -- в чём-то другом, но это решение работает в ситуации, когда всё сломалось, а проблему надо решать срочно. Предположительная причина: платформа 8.3.20 более строго относится к типизации данных в запросах, чем предыдущие версии, вываливая в случае несоблюдения новшеств малопонятные ошибки.

08.04.2022    6278    Kernelbug    26    

34

Отборы динамического списка

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Динамический список предоставляет несколько объектов "Отбор". В статье разбирается, какой для чего нужен и как их использовать на форме. Рассматриваются только возможности платформы (без БСП).

28.03.2022    23500    Gladkov_Anton    5    

66

Фишки платформы 1С 8.3 для начинающего разработчика

Механизмы платформы 1С Платформа 1С v8.3 Конфигурации 1cv8 Россия Бесплатно (free)

В данной заметке рассмотрены вспомогательные инструменты платформы, которыми часто пренебрегают начинающие программисты 1С.

11.03.2022    10663    Dimbayyyy    98    

61

Экспертный кейс. Расследование деградации производительности системы. Проведение документа “Поступление товаров и услуг” (1С:ERP 2)

Механизмы платформы 1С Запросы HighLoad оптимизация Платформа 1С v8.3 1С:ERP Управление предприятием 2 Бесплатно (free)

В ходе проведения нагрузочного тестирования одним из наших клиентов была выявлена сильная деградация производительности системы в целом и, в частности, выполнения ключевой операции “Проведение документа поступление товаров и услуг” в течение выполнения теста. Согласно данным подсистемы БСП “Оценка производительности”, время выполнения ключевой операции “Проведение документа поступление товаров и услуг” возрастало в процессе тестирования с 15-20 секунд в начале тестирования до 150-200 секунд в его финале.

02.03.2022    4039    it-expertise    48    

30

Синхронный и асинхронный вызов в новых версиях платформы

Механизмы платформы 1С Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Начиная с платформы 8.3.18.1128 переработана технология работы с асинхронными вызовами. В данной статье хочу описать новые асинхронные вызовы и сравнить их с предыдущими на примере функции - Вопрос на клиенте.

31.01.2022    6664    Shining_ninja    17    

35

Видеокурс-практикум: как подготовить и написать ТЗ, ЗНР, ЧТЗ. Промо

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

3 500 рублей

Стек технологий для 1С

Инструментарий разработчика Рефакторинг и качество кода Групповая разработка (Git, хранилище) Механизмы платформы 1С Бесплатно (free)

Стек технологий, которые могут быть полезны разработчику на 1С и около 1С. По каждой технологии постарался объяснить, зачем она нужна и с чего начать изучение, если заинтересует.

29.11.2021    29918    mrXoxot    63    

419

Несколько простых приемов для удобной работы в конфигураторе

Универсальные функции Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Простая и удобная среда разработки 1С:Предприятия позволяет практически любому человеку начать работать под капотом 1С - в конфигураторе. Время идет, новички становятся программистами, специалистами, а об удобных приемах работы узнают годами, по ходу своего карьерного пути. А здорово было бы, если бы все знали удобные приемы в начале своего пути? Эти несколько приемов будут полезны новичкам, так как они затрагивают ту область работы, с которой приходится сталкиваться в начале карьеры.

12.11.2021    12149    acces969    95    

138

Как спроектировать структуру регистра сведений

Механизмы платформы 1С Платформа 1С v8.3 Запросы Бесплатно (free)

«Что может быть проще?» — это первое, что приходит в голову. Но что, если это не так? В этой статье мы попробуем затронуть некоторые вопросы, которые могут возникнуть при проектировании больших регистров.

08.11.2021    8677    Neti    60    

108

О вложенных попытках, исключениях и о представлении ошибок

Механизмы платформы 1С Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

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

07.11.2021    12162    Nicholas    22    

46

Обработчик ожидания. Нюансы

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

ПодключитьОбработчикОжидания: некоторые подробности и особенности работы

24.08.2021    24546    Yashazz    25    

62

Работа с 1С:Аналитика Промо

Онлайн-курс предусматривает изучение возможностей системы “1С:Аналитика”, которая работает как составная часть платформы “1С:Предприятие” и обеспечивает оперативный просмотр и анализ необходимых данных.

4500 рублей

Прогресс-бар в поле динамического списка

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Изображаем прогресс-бары в колонке динамического списка

23.08.2021    4473    Yashazz    13    

39

ПриПолученииДанныхНаСервере + Контекст формы. Лайфхак

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Передать свои произвольные данные в событие, которое "без контекста"? Легко!

13.08.2021    7148    Yashazz    16    

43

Новичок новичку: как добавить программно кнопку на форму путем расширения

Механизмы платформы 1С Платформа 1С v8.3 Россия Бесплатно (free)

Рассказываю очень простым языком, как добавить программно кнопку в типовую конфигурацию. Сам новичок в этом деле и рассказываю на "новичковом" языке.

13.05.2021    39945    user1312100    28    

69

Программное создание расширения

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Создание нового расширения "на лету", только штатными средствами 1С.

06.04.2021    6972    Yashazz    16    

77

Программы для исполнения 488-ФЗ: Маркировка товаров Промо

1 января 2019 года вступил в силу ФЗ от 25.12.2018 № 488-ФЗ о единой информационной системе маркировки товаров с использованием контрольных (идентификационных) знаков, который позволяет проследить движение товара от производителя до конечного потребителя. Инфостарт предлагает подборку программ, связанных с применением 488-ФЗ и маркировкой товаров.

Советы из Желтой тетради 📒 #1

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

В этой публикации я собрал в одном месте часть советов и лайфхаков, которые открыл для себя в последнее время. Регулярно я публикую их в своём телеграм-блоге "Жёлтая тетрадь 📒 Блог программиста 1С", здесь же - дайджест этих публикаций.

15.03.2021    6410    builin    120    

52

Расширенный автоподбор при вводе по строке в поле ввода в управляемых формах

Механизмы платформы 1С Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Бесплатно (free)

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

21.01.2021    10358    herfis    9    

48

О формах 1С замолвите слово... Необычное использование знакомого всем объекта

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

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

13.01.2021    10577    CyberCerber    46    

101

Наследование свойств элементов, или Как пользователь может сломать вашу форму

Механизмы платформы 1С Платформа 1С v8.3 Платформа 1C v8.2 Конфигурации 1cv8 Бесплатно (free)

В 1С можно установить свойства ТолькоПросмотр, Доступность и Видимость не только на элементы формы, но и на группы элементов. Но стоит ли так делать? Оказывается, пользователь может обойти запреты, которые установлены на папку. Об этом подробнее в видео.

12.01.2021    6457    SeiOkami    27    

111

Распознавание и загрузка документов в 1С Промо

Универсальная программа-обработка для распознавания любых сканов или фото первичных документов в 1С (счета-фактуры, УПД, ТТН, акты и тд). Точность распознания до 98%.

от 11 рублей

Ускоряем медленный/долгий и тормозной стандартный поиск по динамическому списку, настраиваем его под себя

Механизмы платформы 1С Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Бесплатно (free)

Пользователи привыкли искать на форме списка, но, вбивая в поиск некорректные данные, могут завесить всю систему, а если еще искать нужно по НЕ полям списка, то решение только в своём поиске - все это решим в публикации с открытым кодом.

14.12.2020    39823    SizovE    2    

40

Передача параметров по значению в языке 1С

Механизмы платформы 1С Платформа 1С v8.3 ИТ-компания Бесплатно (free)

Все мы знаем, что в 1С можно написать такое: Процедура ОбработатьОбъект(Знач Объект) КонецПроцедуры Т.е. тем самым мы передаем в процедуру параметр по значению Далее в статье будут рассмотрены некоторые особенности передачи по значению объектов НЕпримитивных типов.

26.11.2020    6166    direktorSan    9    

29

Установка отбора для поля ввода управляемой формы через ПараметрыВыбора (без переопределения событий "НачалоВыбора", "Автоподбор")

Механизмы платформы 1С Платформа 1С v8.3 Управляемые формы Бесплатно (free)

Зачастую возникает необходимость ограничить вывод элементов какого-нибудь справочника или перечисления при редактировании поля ввода (отфильтровать доступные для выбора элементы) эта публикация показывает простой и эффективный способ реализации этого.

15.11.2020    16726    Eugen-S    11    

69

Лайфхаки для разработчиков 1С. Часть 1

Универсальные функции Механизмы платформы 1С Платформа 1С v8.3 Россия Бесплатно (free)

Собрали 20 лайфхаков, которые используют наши программисты при работе с 1С. Формы, контрагенты, СКД, процедуры, глюки платформы и многое другое. В этой статье публикуем первую часть.

30.09.2020    9413    Neti    47    

68

Новое отображение ошибок в 1С

Механизмы платформы 1С Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Рассмотрим развитие механизма отображения ошибок в 1С (начиная с 8.3.17)

10.08.2020    37943    SeiOkami    45    

146