一个动态加载/卸载DLL的例子

原理我就不写了,博客园里很多“大虾”都已经写过了,只说说我的步骤:

1、创建一个新的AppDomain,SubDomain

2、将RemoteLoader(程序集载入器)载入到SubDomain中,并创建RemoteLoader的实例Loader,Loader在SubDomain中创建

3、用Loader.Load方法载入动态程序集Library.DLL,并返回想要得到的对象实例 ca,当然,这个实例也是在SubDomain中创建的(Load方法是泛型方法)

4、给ca的Events属性创建一个EventObj实例,实际上,这个实例在主应用程序域中(这是我用来处理跨AppDomain事件的关键之处)

5、可以使用ca操作了,所有的调用将在SubDomain中执行

6、卸载掉SubDomain后,Library.DLL可以被删除(我发现,Library.DLL不可以和主应用程序放在同一个目录下,否则即使AppDomain被卸载,还是无法被删除,难道是.NET的BUG?)

源码下载(For VS.NET 2005)

转载于:https://www.cnblogs.com/AndyHai/archive/2007/07/15/818815.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简单的C动态链接库的例子: 首先,我们需要创建一个C源文件,例如test.c,包含以下函数的实现: ```c #include <stdio.h> int add(int a, int b) { return a + b; } void print_name() { printf("My name is ChitGPT!\n"); } ``` 然后,我们需要使用编译器将其编译为动态链接库,例如在Windows上使用Visual Studio编译器,我们可以使用以下命令: ``` cl /LD test.c ``` 这将生成一个名为test.dll动态链接库文件。 最后,我们可以在另一个C程序中使用test.dll中的函数,例如: ```c #include <stdio.h> #include <Windows.h> typedef int (*AddFunc)(int, int); typedef void (*PrintNameFunc)(); int main() { HMODULE testDll = LoadLibrary("test.dll"); if (testDll == NULL) { printf("Failed to load test.dll\n"); return 1; } AddFunc add = (AddFunc)GetProcAddress(testDll, "add"); if (add == NULL) { printf("Failed to get address of add function\n"); return 1; } printf("1 + 2 = %d\n", add(1, 2)); PrintNameFunc printName = (PrintNameFunc)GetProcAddress(testDll, "print_name"); if (printName == NULL) { printf("Failed to get address of print_name function\n"); return 1; } printName(); FreeLibrary(testDll); return 0; } ``` 这个程序首先使用LoadLibrary函数加载test.dll动态链接库,然后使用GetProcAddress函数获取test.dll中的add和print_name函数的地址,并调用它们。最后,使用FreeLibrary函数卸载动态链接库。 这就是一个简单的C动态链接库的例子

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值