Visual Basic 编译真正的动态连接库文件
来源:互联网 发布:监控视频播放软件 编辑:程序博客网 时间:2024/06/07 01:03
VB编译文件实际上采取了两次编译的方法,首先是调用c2.exe产生OBJ文件,然后调用Link.exe连接。如果在link的时候添加EXPORT选项,实际上是可以输出函数的。但是,在VB的工程选项中将这些屏蔽了。而且过分的是:VB在Build完成后会将OBJ文件删除,这样就无法通过Link来输出函数了。不过我找到一个比较龌鹾的变通的方法,就是先创建一个Exe工程,在Form_Load事件里面写下面的语句:
Private Sub Form_Load()If (MsgBox("hehe", vbOKCancel) = vbOK) ThenShell "link2.exe " & Command$End IfEndEnd Sub
然后编译为linktemp.exe,接下来将LINK.EXE改名为Link2.exe,将linktemp.exe改名为link.exe。这样在VB调用link.exe时会弹出对话框,处理就会中断。这时就可以有机会将OBJ文件拷贝出来了 J
然后我创建了一个ActiveX DLL工程,在这个工程里面添加一个Module并创建一个Public函数mathadd:
Public Function mathadd(ByVal a As Long, ByVal b As Long) As Longmathadd = a bEnd Function
Builder这个工程,在Link的时候就会中断。然后把创建的Class1.obj、Module1.obj、Project1.obj备份出来。
然后就可以调用Link2.exe连接OBJ到DLL了,我的连接代码是:
<pre name="code" class="html">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 /VERS
注意里面的/ENTRY和/EXPORT开关,/EXPORT开关声明了输出函数mathadd。这样就大功告成了 :-D,可以被其他语言引入,例如在VB中,只需要:
Private Declare Function mathadd Lib "e:/vbdll/ProjectOK.dll" (ByVal a As Long, ByVal b As Long) As Long
就可以了。
0 0
- Visual Basic 编译真正的动态连接库文件
- Visual Basic 编译真正的Dll动态链接库文件
- Visual Basic 2005 连接access库的方法
- 使用Visual Basic 6实现真正实用的多线程处理
- C编译: 动态连接库 (.so文件)
- C编译: 动态连接库 (.so文件)
- C编译: 动态连接库 (.so文件)
- C编译: 动态连接库 (.so文件)
- C编译: 动态连接库 (.so文件)
- C编译: 动态连接库 (.so文件)
- C编译: 动态连接库 (.so文件)
- Visual Basic实现动态报表
- Visual Basic实现动态报表
- Visual Basic 6.0 与 SQL Server 的两种连接
- Visual Basic 的常见问题
- 用户空间动态连接文件编译
- Visual Basic 6.0连接PostgreSQL8.3.3
- 细说 Visual Basic数据连接之 ADO
- IOS 开发中Transform的使用
- 我的故事
- 第十三周项目1-2(从后往前输出数组中元素的值)
- [UI]关于代码手写UI,xib和StoryBoard
- 第十三周项目1-3(输出数组中元素值为3的倍数的数)
- Visual Basic 编译真正的动态连接库文件
- less学习变量的定义(1)
- 第十三周项目一——数组大折腾(4)
- 【扩展知识7】谈const有关的那些事
- Disruptor 无锁同步框架入门
- HDU1720(输入输出涨姿势)
- less 学习 混合(2)
- Linux2.6设备驱动常用的接口函数
- 【牛刀小试5】打印三角