Модератор
|
||||||
1 | ||||||
Создание процедурных DLL в Visual Basic (статья)25.08.2013, 22:19. Показов 44199. Ответов 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 |
25.08.2013, 22:55 | 3 | |||||
Борис, спасибо
Замечательный перевод, читается легко, все коротко и понятно. Подмена аргументов - самый безболезненный способ. Протестировал на Windows 7x64 и 8x64. Работает без ошибок. При чем объявлять библиотеки можно без полного пути. Вот так:
2
|
Модератор
|
|
26.08.2013, 08:26 [ТС] | 4 |
Хотелось бы отметить собственное упущение - весь материал основан на статье (автор: R. Petrusha; опубликована в 2005 г.; в переводе статьи есть ссылка на оригинал). Мой "вклад в проблему" - только перевод и небольшое дополнение в конце (касающееся обработки ошибок).
0
|
26.08.2013, 17:11 | 5 | ||||||||||
Не по теме: Теперь еще осталось разобраться как на VB создавать драйверы. Добавлено через 17 минут Кстати, из другого ЯП функции библиотеки корректно не выполняются. Что этот код.
1
|
26.08.2013, 20:19 | 6 |
Видно, что передаете в функцию число 2 по значению , а в функции обрабатывается ссылка на память по адресу 2.
Надо функции DLL подкорректировать и передавать в функцию указатель на переменную, типа @2, тогда может что и выйдет.
2
|
28.08.2013, 15:16 | 8 | ||||||||||
Всё хорошо, только вот опять столкнулись с той же проблемой, что и в вариант в моей статье - не выходит использовать в других ЯП. У locm не вышло в Basic4GL, а у меня в Delphi:
0
|
locm
|
28.08.2013, 16:15
#9
|
0
|
28.08.2013, 17:11 | 10 | |||||
Так-с, я попробовал передавать функции не число, а указатель на переменную с этим числом, следуя вашему совету.
В итоге получился такой код:
Успешно - с той оговоркой, что функция прибавила единицу не к передаваемому значению (например х=1), а к адресу этого значения, в результате вместо 1+1=2 я получил число 1179650 (т.е. 1179649 - адрес переменной х). Думаю, нужно просто переделать пример для работы с указателями, и у нас будет почти полноценная DLL. Почти - потому что только указатели.
0
|
4 / 4 / 5
Регистрация: 26.02.2013
Сообщений: 42
|
|
16.11.2013, 13:54 | 11 |
Ктонибудь сталкивался с такой проблемой:
1) Делаю DLL как описано выше 2) С помощью CFF Explorer добавляю в "левое" приложение импорт DLL-ки 3) Запускаю "левое" приложение Результат: Ноль реакции! DllMain не вызывается! А если делаю DLL на C++ то все нормально вызывается "левым" приложением! Может я что делаю нетак, помогите плиз!
0
|
16.11.2013, 14:58 | 12 |
А оно на каком ЯП написано?
Потому, что если читали всю тему, то "не выходит использовать в других ЯП DLL, созданные в VB6!" Если у вас современный ЯП, который поддерживает COM, OCX, то надо воспользоваться именно этими возможностями.
0
|
4 / 4 / 5
Регистрация: 26.02.2013
Сообщений: 42
|
|
16.11.2013, 20:31 | 13 |
Тему я всю прочитал. "левое" приложение написано не на ВБ. На чем именно я даже и не разбирался. Смутил просто пост:
Вот и думал может решение уже роддилось, и просто у меня невыходит правильно организовать импорт!
0
|
17.11.2013, 21:00 | 14 |
В самом VB6 работать с этими DLL можно без особых проблем, а вот в других ЯП у нас так и не получилось нормально подключить библиотеку. Программа просто не запускается, либо появляется ошибка при вызове функции из библиотеки.
В ходе экспериментов (в Delphi) мне удалось запустить функцию - я подавал на вход не саму переменную (значение), а её адрес в памяти (указатель). И я сделал вывод, что если переделать всю DLL на работу с указателями, то, возможно, всё получиться. Так что, возможно, решение уже есть, дерзайте и проверьте!
0
|
17.11.2013, 21:07 | 15 |
Мое ИМХО.
VB хорошо подходит для ActiveX-Dll, но для обычных, как говорится "овчинка выделки не стоит". Слишком уж много "если" при разработке такой DLL. Возможно стоит использовать более подходящий инструмент для этого.
0
|
18.11.2013, 00:14 | 16 |
С этим никто не спорит - универсальных языков нет, каждый предназначен для конкретно своей области.
И все наши попытки "танцев с бубном" для реализации нереализуемого, кажется, направлены не на результат, а на сам процесс "танцев"? Ведь практического значения здесь мало всё равно, но теоретически мы доказали эту возможность.
0
|
18.11.2013, 15:43 | 18 |
Рабочий пример на Delphi есть. Программа и функция успешно запускаются и работают, возвращая число (хоть и неправильное).
Ведь до этого, напомню, не запускалась вообще! А так возможность загрузки библиотеки и успешной работы функции теоретически доказана. Не практически - потому что нужно саму библиотеку под указатели переделать.
0
|
20.11.2013, 15:14 | 20 | |||||||||||||||
Дизассемблировал DLL. Код функции Increment.
Рабочий код вызова функции из VB DLL.
0
|
20.11.2013, 15:14 | |
20.11.2013, 15:14 | |
Помогаю со студенческими работами здесь
20
Использование библиотеки dll написанной в Visual Basic Можно ли в Visual Basic использовать стандартные Windows DLL? Visual Basic 6 DLL для работы с php файлами Visual Basic вылетает с ошибкой при попытке вызова функции из DLL проблема с использованием функции в проекте Visual Basic, вызываемой из DLL написаной на Delphi5 Вычисление значений функции двух переменных в Visual Basic - Visual Basic Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |