Многопоточность в VBA01.07.2023, 15:39. Показов 7481. Ответов 102
Метки multithreading in vba (Все метки)
Почему VBA? Про VB в принципе уже все давно расписано и исследовано за десятки лет. На VBA тема менее популярна, по в принципе понятным причинам, по скольку, там она не сильно так уж и нужна. Мне также в ней нет особой необходимости, просто некоторый интерес прощупать эту тему с точки зрения "простого обывателя", на сколько далеко можно зайти и т.д.
Вообще, говоря, на VBA есть довольно простая и удобная не очень изящная возможность организовать "потоки" за счет запуска нескольких копий приложения, также можно делать на VBS. Далее простой пример (в файле), назовем "Игра - Останови колобка если сможешь!" ). В примере все не очень оптимально, и нет какого-то полезного шаблона, но как мне кажется хорошо видно работу т.н. маршаллинга, его усточивую работу, даже при не очень, как бы правильной ситации. При запуске множества экземпляров Экселя и их одновременному обращению к одному и тому же объекту, все продолжает работать довольно устойчиво при том, что объектная модель отдельного Экселя "общается" со всеми в одном потоке или точнее из одного потока. Видимо маршаллинг все разруливает. В данном примере, не мало важно, что рабоает пропуск ошибок и doevents. Если попытаться реализовать подобное с помощью win-api то с этим уже появляются некоторые проблеммки.. и бог весть еще с чем, а вот при работе разных экземпляров Эксель все очень просто.
0
|
|
| 01.07.2023, 15:39 | |
|
Ответы с готовыми решениями:
102
VBA → SSMS → VBA. Вызов хранимой процедуры SSMS из VBA с возвратом 2ух и более параметров Программа в VBA для проверки гипотез про равенство средних - VBA VBA и Oracle: stored procedure из VBA и сохранение текста в переменной |
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
||
| 06.07.2023, 13:42 | ||
|
0
|
||
| 06.07.2023, 13:50 [ТС] | |
|
HackerVlad, я сначала смотрел у Трика, но ни фига не понял, но взял у него функцию расшаривания памяти, и нашел более простой пример по этой функции. Одной функцией разшариваешь, на одной стороне, на другой стороне подключаешься к этой "шаре" по текстовому имени. Это получается вроде бы как зарезервированное место файла подкачки, отображенное в оперативную память. Потом выложу.
0
|
|
|
Модератор
|
||
| 06.07.2023, 13:58 | ||
1
|
||
| 06.07.2023, 18:28 [ТС] | |
|
Вообще, было бы круто, если бы vba запускался отдельно от софта. На Autocad он сейчас отдельно устанавливается, на wps офис раньше поставлялся в виде установочного пакета. Надо будет глянуть как он там прикручен.
0
|
|
| 07.07.2023, 10:00 [ТС] | |||||||||||||||||||
|
"Возвращаясь к нашим баранам".. Также ранее заметил один примечательный момент, что один поток всеже работает довольно утойчиво (при условиях, описанных в #39). Стоит запустить второй - все уже становится хрупко. Например в одном потоке можно сделать вывод в ячейку текущего времени каждую секунду. При этом можно что-либо делать на листе, выделять, редактировть. Либо процедуру Майкла (см #35) поставить в цикл и она также будет прекрасно отрабатывать (не смотря на то, что там многочисленные рекурсии), и далее поток можно корректно завершить.
Добавлено через 4 часа 45 минут Отправной модуль (где создается шара) Кликните здесь для просмотра всего текста
Принимающий модуль Кликните здесь для просмотра всего текста
1
|
|||||||||||||||||||
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
|
| 07.07.2023, 10:38 | |
|
testuser2, молодец! только жаль для VB6 примера нет...
0
|
|
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
|
| 08.07.2023, 10:08 | |
|
Да успокойся с этими потоками ты уже) это не для VBA явно)
0
|
|
| 08.07.2023, 10:19 [ТС] | |
|
Я не успокоюсь пока мне не скажут, такой вариант можно реализовать? Если связующий класс реализовать в библиотеке
0
|
|
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
|
| 08.07.2023, 11:13 | |
|
testuser2, там что-то такое интересное ажно за 1997 год)))
Добавлено через 47 минут так это что статья Дан Эплмана? Тот который впервые писал о многопоточности в VB? Добавлено через 1 минуту Я читал его книгу бумажную, пытался что-то делать тогда, ещё лет 20 назад, по многопоточности, но у меня так ничего и не получалось. У The Trick'а всё гораздо лучше описано. Добавлено через 1 минуту Хотя если честно я многопоточность до сих пор так и не освоил. Надо этим плотно заниматься, читать статьи The Trick'а и смотреть его примеры. У Дана Эплмана будет в любом случае глючная ерунда. Добавлено через 1 минуту Даже проект который скачал уже глючит! Постоянный вылет из среды VB6. У The Trick'а ничего не глючит.
0
|
|
| 08.07.2023, 11:28 [ТС] | |||||||||||
|
В общем клас создал как в статье, ActiveX-библиотеку скомпилировал в p-code, нашел CLSID класса в реестре. Вопрос куда его прописать в процедуре InitializeIID
Кликните здесь для просмотра всего текста
0
|
|||||||||||
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
|
| 08.07.2023, 13:02 | |
|
testuser2, ты у меня спрашиваешь? я даже не знаю, что такое маршалинг)))
Добавлено через 1 час 30 минут testuser2, если бы ты мне прислал проект на vb6, я бы посмотрел конечно, а то в этом vba я ничего не понимаю, ну что, разобрался там?
0
|
|
| 08.07.2023, 14:26 [ТС] | ||
|
HackerVlad, будет все попозжа, буду делать, по образцу Трика, когда спадет жара. Надо будет получить CLSID, и IID класса. Наверное можно с помощью OleView. Вот интересная тема
Добавлено через 13 минут У Трика ест про все эти моменты, ктсати
0
|
||
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
|
| 08.07.2023, 17:26 | |
|
Да у The Trick'а это всё есть, но тут с помощью DLL, а у The Trick'а есть даже без всяких там DLL дополнительных.
0
|
|
| 08.07.2023, 18:10 [ТС] | ||
|
0
|
||
|
Модератор
|
|||
| 08.07.2023, 21:00 | |||
|
2
|
|||
| 09.07.2023, 09:37 [ТС] | ||
|
Попробую с его библиотекой инициализировать еще
0
|
||
| 09.07.2023, 09:37 | |
|
VBA-проект для создания эл. сообщения в MS Outlook из-под любого VBA-приложения. VBA AutoCad - как снять (изменить) ограничение времени выполнения VBA Макроса? VBA SDK. Как включить в проект на VBA конструкторы? Купил книгу По VBA Программирование на VBA 2003 В.Г.Кузьменко Как получить ссылку на VBA-объект Application в DLL, которая привязана к этому VBA-приложению Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Сезонность закисления почв
anaschu 04.07.2026
200 часов это все равно моловато. Есть ситуации, но нестандартные, когда смена происходит за 5 лет.
Но обычно это 50 лет и более.
Наверное, закисление почвы происходит сезонно в средней. . .
|
В чем ценность человеческого опыта в глобальном смысле?
kumehtar 03.07.2026
Возможно, ценность человека не в том, что он однажды достигает мудрости, а в том, что он становится носителем карты пути. Он знает не только истину, но и последовательность внутренних изменений,. . .
|
интеграция AnyLogic с самописным REST API и переход на Odoo
anaschu 03.07.2026
Успешная интеграция AnyLogic с самописным REST API и переход на промышленную Odoo WMS
Сегодня проделал огромный путь от простой симуляции физических процессов до построения полноценной. . .
|
Поиск всех путей на ориентированном графе. Linux
dcc0 02.07.2026
Переработка старого кода из моей статьи.
Через несколько переработок от PHP кода к C89 (надеюсь, 89).
Но довольно запутанно получилось. Код для Linux.
Но если убрать time и то, что с ним. . .
|
|
Сам себя обучал rest api
anaschu 02.07.2026
Педагогический лайфхак: Почему чистый REST API для ученика намного круче, чем готовые библиотеки
Когда мы отказались от капризного JAR-файла AnyLogic и переписали код на стандартный HttpClient,. . .
|
rest api anylogic - выполнение модели на своём русском сайте
anaschu 02.07.2026
Как подружиться с AnyLogic Cloud API, победить провайдеров и развернуться Java-бэкенд в Docker на бесплатном хостинге: Двухдневный лог борьбы
Всем привет! Хочу поделиться свежим (и довольно. . .
|
Где деньги лежат
kumehtar 02.07.2026
Это - японская подводная лодка I-52 (тип C2, кодовое имя Momi) вышла из Японии в марте 1944 года с миссией в оккупированную немцами Францию (Лорьян). Это была одна из «Янаги»-миссий по обмену. . .
|
Krabik для WoW 3.3.5a, многоязычный
AmbA 02.07.2026
Допилил бота, думаю что окончательно. Изменения:
- добавлена многоязычность
- добавлено снятие скриншотов
- добавлено поддержание бафов хождения по воде (для жреца, дк и шамана)
- и так, по. . .
|