老问题重新问一下。我自己VB6做一个简单的Dll,内部代码如下:
Public Function Rectangle(a, b As Integer) As Integer
Rectangle = a * b
End Function
///////////////////////////////////////////////////////////////////////之后我再用VB调用其函数,VB代码如下:
Private Declare Function Rectangle Lib "MyDll.dll" (ByVal L As Integer, ByVal W As Integer) As Integer Private Sub Command1_Click()
Me.Caption = Rectangle(5, 5)
End Sub 结果运行并单击COmmand1时提示错误:
实时错误‘453’
找不到DLL入口点Rectangle in MyDll.dll。 ///////////////////////////////////////////////////////////////////////////////////////////////
(注:之前的楼上提的把Public改为Private已经改过,但出现另一种错误)
以上不解,请大家指教!! 以上谢谢!!
Public Function Rectangle(a, b As Integer) As Integer
Rectangle = a * b
End Function
///////////////////////////////////////////////////////////////////////之后我再用VB调用其函数,VB代码如下:
Private Declare Function Rectangle Lib "MyDll.dll" (ByVal L As Integer, ByVal W As Integer) As Integer Private Sub Command1_Click()
Me.Caption = Rectangle(5, 5)
End Sub 结果运行并单击COmmand1时提示错误:
实时错误‘453’
找不到DLL入口点Rectangle in MyDll.dll。 ///////////////////////////////////////////////////////////////////////////////////////////////
(注:之前的楼上提的把Public改为Private已经改过,但出现另一种错误)
以上不解,请大家指教!! 以上谢谢!!
解决方案 »
- 恭喜影子童鞋重返版主团队~~~上任网络编程版主·~~
- 俺新手,问个简单的问题
- 代码中,每个过程或是函数是不是都应该加上 on error 的处理呀?可是我看一些经典代码也不是全加的呀?规范的作法是什么?
- 用过Wise Installation System打包MSDE的达人请进
- 简单问题,两个表合并的SQL语句?
- 有那位有拦截文件移动、复制、删除的HOOK源代码吗?
- 高手给看一下!给改一下!
- 请问菜单左边的一长条图片是怎么加上去的?(不是小图标,像98的开始菜单)
- 我用D3D将一幅图片显示在屏幕(surface)上,请问能否用GDI的方法把图像Copy到PictureBox上?
- 使用vb如何判断和删除iis上的站点
- 我对多线程不懂,谁能举出一个易懂的多线程例子。比如程序中利用VB的timer控件是否是多线程。
- 初次做VB的DLL,请大家帮忙!
在Dll是不是已经声明了a,b as integer了吗?
希望帮我解译清楚一点以上谢谢1
Private Declare Function Rectangle Lib "MyDll.dll" (ByVal L As Integer, ByVal W As Integer) As Integer
VB的生成Dll不是windows 标准的dll
需通过"工程"-->"引用" 后就可以用了.
Rectangle = a * b
End Function
分开来定义
Public Function Rectangle(ByVal a As Integer,ByVal b As Integer) As Integer
Rectangle = a * b
End Function
生成Dll先通过"工程"-- >"引用" 并确保你已经在windows中注册.
另外你可以使用下面这种方式引用看看
Dim obj As Object
Set obj=CreateObject("XXX.XXX")
前面有人提到过LINK.EXE,这是什么,能不能帮我解译清楚一点?
Public Function Rectangle(ByVal a As Integer,ByVal b As Integer) As Integer
Rectangle = a * b
End Function
编译成"mytestdll.dll"新建一工程,通过"工程"-- >"引用"-"mytestdll.dll"private sub command1_click
Dim obj As Object
Set obj=CreateObject("mytestdll.myclass")
'DLL名加其中的CLASS名
text1.text=obj.rectangle(2,3)
end sub这样就可见到text1中的运算值了
******************************************
用下面的语句调用就不行了Private Declare Function Rectangle Lib "MyDll.dll" (ByVal L As Integer, ByVal W As Integer) As Integer
我试了一下你的方法,的确可以实现,但不知为什么要这样做。
现在和一个用VC的编程员合作,我现在在使用VC的DLL时老是提示打不到DLL文件,在引用时提示不能将引用添加到指定文件,在用regsvr32注册时提示不找不到指定模块。
VB试用DLL真上我费解,大家推荐一下资料给我参考一下吧,谢谢!
能解决DLL入口点的问题就好了,就象12楼提供的资料里面一样,让VB能搞定下面的内容:
NAME MathLib
LIBRARY MathMod
DESCRIPTION "Add-on Library of Mathematical Routines"
EXPORTS DllMain @1
Increment @2
Decrement @3
Square @4
找不到DLL文件试试这样:把DLL放到...\system32(指XP,2000系统)下看看,不用注册
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
转载