怎样用VB编写.DLL动态链接库文件
来源:互联网 发布:excel表格数据分类 编辑:程序博客网 时间:2024/05/22 00:14
VB中创建的DLL只是COM组件,无法作为输出函数的DLL,其实这只是个错误的说法。其实MS非常狡猾,如果你是个VB疯狂发烧友的话,应该早就狂试出这种可以创建输出函数的DLL的方法。
VB编译文件实际上采取了两次编译的方法,首先是调用C2.exe产生*.OBJ文件,然后调用Link.EXE连接。如果在LINK的时候添加EXPORT选项,实际上是可以输出函数的。但是,在VB的工程选项中将这些屏蔽了。而且过分的是:VB在Build完成后会将OBJ文件删除,这样就无法手动通过Link来创建我们需要的DLL了。不过我找到一个比较龌鹾的变通的方法,就是先创建一个Exe工程,在Form_Load事件里面写下面的语句:
Sub Main
If MsgBox("哈哈", vbOKCancel) = vbOK Then
Shell "link2.exe " & Command$
End If
End Sub
然后编译为LinkTemp.EXE,接下来将LINK.EXE改名为Link2.exe,将LinkTemp.EXE改名为Link.EXE。这样在VB调用Link.EXE时会弹出对话框,处理就会中断。这时就可以有机会将OBJ文件拷贝出来了。
然后我创建了一个ActiveX DLL工程,在这个工程里面添加一个Module并创建一个Public函数mathadd:
Public Function mathadd(ByVal a As Long, ByVal b As Long) As Long
mathadd = a + b
End Function
编译这个工程,在Link的时候就会中断。然后把创建的Class1.obj、Module1.obj、Project1.obj备份出来。
然后就可以调用Link2.exe连接OBJ到DLL了,我的连接代码是:
Link2.exe "e:\vbdll\Class1.obj" "e:\vbdll\Module1.obj" "e:\vbdll\Project1.obj" "E:\Program Files\Microsoft Visual Studio\VB98\VBAEXE6.LIB" /ENTRY:__vbaS /EXPORT:mathadd /OUT:"e:\vbdll\ProjectOK.dll" /BASE:0x11000000 /SUBSYSTEM:WINDOWS,4.0 /VERSION:1.0 /Dll /INCREMENTAL:NO /OPT:REF /MERGE:.rdata=.text /IGNORE:4078
注意里面的/ENTRY和/EXPORT开关,/EXPORT开关声明了输出函数mathadd。这样就大功告成了,可以被其他语言引入,例如在VB中,只需要:
Private Declare Function mathadd Lib "e:\vbdll\ProjectOK.dll" (ByVal a As Long, ByVal b As Long) As Long
- 怎样用VB编写.DLL动态链接库文件
- 怎样用VB编写.DLL动态链接库文件
- 怎样用VB编写.DLL动态链接库文件
- 怎样用VB编写.DLL动态链接库文件
- VB编写.DLL动态链接库文件
- dll动态链接库文件编写
- 用VB编写DLL动态链接库方法
- 用VB编写DLL动态链接库方法
- 采用VB编写的动态链接库(ActiveX DLL)
- 编写.dll动态链接库
- C#调用C++编写的动态链接库dll文件
- C#编写动态链接库类库dll文件
- C语言编写DLL动态链接库并分别用VB和Python调用
- 为Symbian编写动态链接库DLL
- 为Symbian编写动态链接库DLL
- 为Symbian编写动态链接库DLL
- 为Symbian编写动态链接库DLL
- 为Symbian编写动态链接库DLL
- css计数器
- 邮件发送
- modbus4j.jar实现modbus tcp协议
- Bitcask存储模型
- Java的进制介绍
- 怎样用VB编写.DLL动态链接库文件
- 权限控制的另类做法
- 设置overflow:auto表格没有滚动条的解决办法
- 杭电1263 水果
- 17.3 逻辑字体
- javascript常用控件
- AndroidUI简单设置
- MySQL数据导出与导入
- 数据结构与算法------二分查找