1.C语言如何调用DLL
//dll
#include <windows.h>
extern "C" //保持C语言文件
void _declspec ( dllexport ) tryProc() //定义函数
{
MessageBox(NULL,_T("a"),_T("a"),MB_OK);
}-------------------------------------
//C
#include <windows.h>
int main()
{
HMOUDLE dll = LoadLibrary(/*DLL文件名*/);
if(dll != NULL)
{
FARPROC try = GetProcAddress(dll,"tryProc");
if(try != NULL)
{
tryProc();//假如函数有返回值,可以用try()得到返回值
/*_asm call tryProc*/
}
}
return 0;
}
2.C程序如何调用dll 文件
用的IDE不一样,生成DLL文件的方法也有差异,建议上网查找你所用的IDE生成DLL文件的方法。
***********************************************
这个关键是IDE(比如是VC++还是BCB),C语言在编DLL和其它的程序时都用相同的规则。
***********************************************
看不懂建议暂时就不要自己做了,在这里说和你看网上资料是一样的,而且这里可以说的内容还不及网上多呢。
3.C#中怎样引用c编写的dll
使用C#生成dll文件并调用 一、创建dll文件:例如生成一个md5编码判断状态的文件,即,输入一个字符串(string A)和一个32位md5编码(string B),判断此字符串A对应的32位md5编码是否与B相等,如果相等返回true,否则返回false。
打开VS 2005,“文件”--》“新建”--“项目”,选择“Windows 控件库”,命名后点击“确定”,在“UserControl1.cs”中输入以下代码:using System; using System.Collections.Generic; using System.ComponentModel; using System.Drawing; using System.Data; using System.Windows.Forms; using System.Text; using System.Security.Cryptography; namespace md5 { public partial class Program : UserControl {#region MD5 32位加密:GetMd5Str32/// /// 32位MD5加密/// /// 待加密字串/// 加密后的字串 public static string GetMd5Str32(string strSource) { byte[] bytes = Encoding.ASCII.GetBytes(strSource); byte[] hashValue = ((System.Security.Cryptography.HashAlgorithm)System.Security.Cryptography.CryptoConfig.CreateFromName("MD5")).ComputeHash(bytes); StringBuilder sb = new StringBuilder(); for (int i = 0; i { sb.Append(hashValue[i].ToString("x2")); } return sb.ToString().ToUpper(); }#endregion#region 核对md5编码是否一致:CheckMd5String()/// /// 核对md5编码是否一致/// /// /// 如果一致返回true,否则返回false/// public static bool CheckMd5String(string str1, string str2) { string md5String = str1; //需要验证的字符串 string md5DbString = str2; //需要核对的32位md5编码 int result = string.Compare(md5.Program.GetMd5Str32(str1), md5DbString, true); if (result == 0) { return true; } else { return false; } }#endregion } } 修改“UserControl1.Designer.cs”中的命名空间为“md5”,方法为“Program”,即可生成dll文件。在。
\bin\Debug文件假下,可以找到相应的dll文件。二、部署dll流程:首先把dll文件放到应用程序。
\bin\Debug\下;然后在解决方案中添加引用:右键鼠标-->添加引用-->浏览-->选择dll放置路径后点击“确定”。注意:要在应用文件头处使用using md5;命令。
测试应用程序代码,如下:Form1.cs using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Text; using System.Windows.Forms; using md5; namespace WindowsApplication1 { public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void button1_Click(object sender, EventArgs e) { string str1 = textBox1.Text.ToString(); string md5String = textBox2.Text.ToString(); textBox3.Text = md5.Program.GetMd5Str32(str1); textBox4.Text = md5.Program.CheckMd5String(str1, md5String).ToString(); } private void button2_Click(object sender, EventArgs e) { this.Close(); } } } 三、注意点:1、在C#应用程序开发过程中,加载dll文件时,报错“未能加载文件或程序集“md5, Version=2.0.0.0, Culture=neutral, PublicKeyToken=null”或它的某一个依赖项。系统找不到指定的文件。”
请指点一下是什么原因?解决:这是因为加载dll的路径问题,正确加载方式为:在“解决方案”的“引用”文件上右击鼠标,选择“添加引用”---》在“浏览”选项卡中添加引用(注意:自己定义的dll文件不能在“.NET”选项卡中添加。)------------------------------------------------------------------------------------------------------------------ c#生成DLL文件,内部函数的问题 用C#编写一组处理XML文档的代码,由于要求生成DLL文件,并由外部的其他工具访问动态库中的文件,但是用Dependency Walker检测我生成的这个DLL文件没有显示任何的函数,以前没做过这方面的东西,求教了 代码如下:using System; using System.IO; using System.Xml; public class Sample { public static void Main() { DeleteArg(); } static void DeleteArg() { XmlDocument doc = new XmlDocument(); doc.Load(@"c:\\data1.xml"); XmlNode root = doc.DocumentElement; XmlNode Node1; XmlNodeList nodeList = doc.SelectSingleNode("/Entity/Columns").ChildNodes; foreach (XmlNode xn in nodeList) { XmlElement xe = (XmlElement)xn; if (xe.GetAttribute("Name") == "SysModuleID") { xe.RemoveAll();//xe.RemoveAttribute("Name");//删除Name属性 } } doc.Save("c:\\data1.xml");//保存这个文档到文件中 } } 以上代码实现删除XML文件中某一节点的功能,如何在生成DLL后能够使用检测工具检测出DeleteArg函数,使用Dependency Walker没检测出该函数是不是以为着这个动态库文件不能被调用.---- 因为.net的程序不是这样把函数放在导出表的, 我记得.net做的dll只导出了一个_CorDllMain的方法,所以用Dependency Walker是看不出来的. 如果你想看.net做的dll导出了什么内容,可以用反射查看元数据---- 生成这个DLL库文件,是想要别的工具运行这个动态库文件,实现DELETEARG()这个函数的功能---- 可以的---- 你上面的代码不是生成DLL的,而是。
4.C中如何调用DLL
dll代码:
#include
extern "C"
void _declspec( dllexport )
Msg()
{
MessageBox(NULL,"hello world!","demo",MB_OK);
}
编译完成后把dll命名为fuck.dll ,放到 c盘下。
调用dll的exe的代码:
#include
int main()
{
HMODULE hdll=LoadLibrary("c:\\fuck.dll"); //加载dll
if(hdll!=NULL)
{
FARPROC proc=GetProcAddress(hdll,"Msg");
if(proc!=NULL)
{
//proc();
_asm call proc
}
}
return 0;
}
5.C语言如何调用DLL
typedef __stdcall void (*MYPROC)(char*);
pascal是使用stdcall调用约定的,而c默认是__cdecl
研究半天,搞定了
delphi文件:
library delphi;
procedure Show123(msg:pchar);stdcall;
begin
writeln(msg);
end;
exports Show123;
begin
end.
c调用:
#include <windows.h>
extern "C" typedef void (__stdcall *PShow123)(char* str);
int main()
{
HMODULE hModule = LoadLibrary("delphi.dll"); // 这里换成你自己的dll名
if(!hModule)
return 0;
PShow123 Show123 = (PShow123)GetProcAddress(hModule, "Show123");
if(!Show123)
return 0;
Show123("123123");
FreeLibrary(hModule);
return 0;
}
已经测试成功
6.如何用c/c++编写和调用dll动态链接库
假设名为a.dll导出了函数int sum(int a, int b);
应这样调用:
HMODULE hLib = LoadLibrary("a.dll"); //加载a.dll,这里是假设a.dll与程序放在同一目录
typedef int (*funcSum)(int,int); // 定义函数指针
funcSum sum = (funcSum) GetProcAddress(hLib, "sum"); //获取函数地址
int ret = sum(1,2); //调用
FreeLibrary(hLib); //释放
7.c语言如何调用dll动态链接库
这是我以前的回答,是个两数加法的例子,看了就明白了
你的dll不必用h头文件,你用的是显式声明导出函数
vc在显式声明函数时会出现与vb不匹配的问题,他会把函数名改了,你必须用隐式声明,就是def文件声明才可以。
你的cpp里直接写
int __stdcall add(int a, int b)
{
return (a+b);
}
然后再在工程里添加一个文本文件,注意,文件名是 makedll(如果不对就是工程名).def
里面写
LIBRARY makedll
EXPORTS
add @1
然后保存
编译、连接
得到的dll就是vb可以调用的了
vb里呢,不用怎么改
如下
Public Declare Function add Lib "makedll.dll" (ByVal a As Integer,ByVal b As Integer) As Integer
Private Sub Command1_Click()
Dim c As Integer
c = add(1, 2)
MsgBox c
End Sub
这有就应该没问题了
8.怎样用C编写DLL?
要做自己的 动态连接库,首先要知道DLL在VC5.0中都有哪几种分类。
VC支持三种DLL,它们是: 1.Non-MFC Dlls 2.Regular Dlls 3.Extension Dlls Note:翻译措辞不当,故遇到术语是引用原词 Non-MFC DLL:指的是不用MFC的类库结构,直接用C语言写的DLL,其输出的函数一 般用的是标准C接口,并能被非MFC或MFC编写的应用程序所调用。LL, Regular DLL:和下述的Extension Dlls一样,是用MFC类库编写的。
明显的特点是 在源文件里有一个继承CWinApp的类。其又可细分成静态连接到MFC和动态连接到MFC上 的。
但静态连接到MFC的动态连接库只被VC的专业般和企业版所支持。 Extension DLL:用来实现从MFC所继承下来的类的重新利用,也就是说,用这种类 型的动态连接库,可以用来输出一个从MFC所继承下来的类。
Extension DLL使用MFC的 动态连接版本所创建的,并且它只被用MFC类库所编写的应用程序所调用。 各位看到这里如果眼有点花或头有点晕,请别泄气,再看两遍,然后继续往下看, 定有收获。
标 题: 关于VC中的DLL的编程[1] 这一节介绍Non-MFC DLLs的编写方法。下面是一个通用的 写法: BOOL APIENTRY DllMain(HANDLE hModule,DWORD ul_reason_for_call, LPVOID lpReserved) { switch( ul_reason_for_call ) { case DLL_PROCESS_ATTACH: 。
. case DLL_THREAD_ATTACH: 。
. case DLL_THREAD_DETACH: 。
. case DLL_PROCESS_DETACH: 。
. } return TRUE; } 每一个DLL必须有一个入口点,这就象我们用C编写的应用程序一样, 必须有一个WINMAIN函数一样。
在这个示例中,DllMain是一个缺省的入口函数,你不需要编写自己 的DLL入口函数,并用linker的命令行的参数开关/ENTRY声明。用这个缺 省的入口函数就能使动态连接库被调用时得到正确的初始化,当然了,你 不要在初始化的时候填写使系统崩溃的代码了。
参数中,hMoudle是动态库被调用时所传递来的一个指向自己的句柄 (实际上,它是指向_DGROUP段的一个选择符) ul_reason_for_call是一个说明动态库被调原因的标志。当进程或线程 装入或卸载动态连接库的时候,操作系统调用入口函数,并说明动态连接库 被调用的原因。
它所有的可能值为: DLL_PROCESS_ATTACH: 进程被调用 DLL_THREAD_ATTACH: 线程被调用 DLL_PROCESS_DETACH: 进程被停止 DLL_THREAD_DETACH: 线程被停止 lpReserved是一个被系统所保留的参数。 入口函数已经写了,盛下的也不难,你可以在文件中加入你所想要输 出的函数或变量或c++类或、或、或、?好象差部多了。
Look here!现在就 要加入一个新的输出函数了: void _declspec(dllexport) JustSoSo() { MessageBox(NULL,"It's so easy!","Hahaha。
",MB_OK); } 要输出一个类也可以,如下: class _declspec(dllexport) Easy { //add your class definition。 }; 各位一定注意到在输出函数或类是我用到_declspec(dllexport), 这是VC提供的一个关键字,用它可在动态连接库中输出一个数据、一个函数或一个类。
用这个关键字可省你不少事,你不用在.DEF文件 中说明我要输出这个类、那个函数的。 Ok!各位照着上面的例子试着敲敲看,Just so easy! 先说到这了。