Модератор
|
||||||
1 | ||||||
Создание процедурных DLL в Visual Basic (статья)25.08.2013, 22:19. Показов 45072. Ответов 74
Метки нет (Все метки)
Создание процедурных DLL в Visual Basic Несколько слов о резонах создания процедурных Dll на VB. Как известно, VB позволяет без проблем создавать ActiveX-Dll. Эта возможность в целом решает проблему повторного использования кода. Однако, есть два момента, которые могут сделать использование ActiveX-Dll (т.е. COM) не вполне удобным. Первая проблема состоит в том, что ActiveX-Dll нельзя просто скопировать - нужна регистрация (т.е. административные права). А при повсеместном внедрении политик безопасности, получение прав администратора вырастает в большую проблему. Использование процедурных dll не требует регистрации. Вторая проблема состоит в том, что интенсивное использование кода из ActiveX-Dll (даже при раннем связывании) все-таки медленнее, чем использование кода из своей программы (или из процедурной dll) - ведь соблюдение стандарта COM требует ресурсов... И особенно больших, если используется ActiveX-Exe. Все это делает создание процедурных dll на VB достаточно актуальным. Теперь к делу! Интересующиеся деталями могут прочитать мой перевод статьи "Создание процедурных DLL в Visual Basic". А для "занятых" могу сказать следующее: 1) Скопируйте и разверните прилагаемый архив с примерами 2) из поддиректории link-2 возьмите модуль linkk.exe; перенесите его в установочную директорию VB (она обычно располагается по адресу \Program Files\Microsoft Visual Studio\Vb98); модуль LINK.EXE переименуйте в LINKLNK.EXE, а модуль linkk.exe -> LINK.EXE 3) Для создание dll действуйте так: - создавайте проект ActiveX-DLL (и назовите myLib) - модуль класса не трогайте - добавьте в проект стандартный модуль и занесите в него следующее:
NAME myLib LIBRARY MathMod DESCRIPTION "... ..." EXPORTS DllMain @1 Increment @2 Decrement @3 Square @4 getLastError @5 ClearError @6 - транслируйте проект обычным образом в среде IDE - получится процедурная DLL! Для проверки работспособности DLL можно написать отдельный тестирующий модуль, в котором написать нужные операторы Declare для использования наших функций. Все, разложенные по директориям, исходники прилагаются:
14
|
25.08.2013, 22:19 | |
Ответы с готовыми решениями:
74
Работа с DLL в Visual Basic (статья) Создание dll на основе Visual Basic Способы передачи данных с Visual Basic в Excel (статья) Visual Basic + VC++ DLL = ошибка Bad DLL calling convertation |
0 / 0 / 0
Регистрация: 23.11.2015
Сообщений: 2
|
|
24.11.2015, 18:38 | 61 |
Спасибо за ответ! Как мне уже удалось установить, что на VB6 вообще нет возможности создания 64-битных dll и видимо придется осваивать и переделывать код под VB.Net
0
|
Модератор
|
|
20.06.2017, 00:21 | 64 |
Если поток и проект инициализирован то да. Нужно обратить внимание на время жизни объекта и обеспечить нахождение dll в памяти пока хоть один экземпляр класса находится в памяти. Это довольно-таки сложная задача, проще использовать стандартный механизм.
Обычно создают общий интерфейс для всех классов. Потому что никакой инициализации нет.
3
|
Модератор
|
|
30.07.2017, 14:12 | 66 |
Не обязательно, в зависимости от задачи.
Да, в статье ошибка, но это почти никак не скажется на работе приведенной Dll. Там также ошибка в типе возвращаемого значения DllMain. Гайд по созданию DLL на VB6.
2
|
0 / 0 / 0
Регистрация: 31.10.2017
Сообщений: 12
|
||||||
02.11.2017, 09:45 | 67 | |||||
Добрый день.
Заранее прошу прощения, если спрашиваю в неправильной ветке, но ответа на форму не нашёл. Попробовал Ваш способ создания dll. В VB6 всё отрабатывает отлично. Но при переносе формы из Вашего проекта в Excel появляются ошибки: Добавление простых строк приводит к ошибке
Вопрос один - что не так?
0
|
0 / 0 / 0
Регистрация: 31.10.2017
Сообщений: 12
|
|
02.11.2017, 10:38 | 69 |
Нет. Спасибо. Попробую.
Я, признаться, полагал, что и первоначальном примере при экспорте кода в Excel всё должно было работать - ведь вызывал-то MsgBox, не более.
0
|
Модератор
|
|
02.11.2017, 10:49 | 70 |
Нет. MsgBox потокозависимая функция. MsgBox это необязательно показ сообщения, в зависимости от условий это может быть и запись сообщения в журнал событий (ReportEvent).
1
|
0 / 0 / 0
Регистрация: 31.10.2017
Сообщений: 12
|
|
04.11.2017, 00:30 | 71 |
Заработало по Вашему способу. Однако, только в 32х битном Excel на Windows XP.
При запуске на Windows 7 x64 и 32х битном Excel dll подгружается, функции определяются, но при вызове функций в коде Excel вылетает. Полагаю, что дело в "битности". Возможна ли адаптация Вашего способа под x64? Существуют ли универсальные варианты х32-х64? Заранее благодарю за любую помощь.
0
|
0 / 0 / 0
Регистрация: 31.10.2017
Сообщений: 12
|
|
04.11.2017, 17:29 | 73 |
DLL, исходники, excel с формой вызова в приложении
0
|
0 / 0 / 0
Регистрация: 31.10.2017
Сообщений: 12
|
|
04.11.2017, 22:38 | 75 |
Всё получилось. Огромное спасибо за помощь!
0
|
04.11.2017, 22:38 | |
04.11.2017, 22:38 | |
Помогаю со студенческими работами здесь
75
Использование библиотеки dll написанной в Visual Basic Можно ли в Visual Basic использовать стандартные Windows DLL? Visual Basic 6 DLL для работы с php файлами Visual Basic вылетает с ошибкой при попытке вызова функции из DLL проблема с использованием функции в проекте Visual Basic, вызываемой из DLL написаной на Delphi5 Вычисление значений функции двух переменных в Visual Basic - Visual Basic Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |