在C#项目开发过程中,我们经常会遇到需要调用外部DLL的情况,大部分时候我们是通过直接添加引用的方式使用DLL,但有些场景下,比如插件化开发、运行时按需加载功能模块,提前引用DLL并不现实,这时候就需要用到动态调用DLL的技术。

动态调用DLL的核心原理
C#动态调用DLL主要依赖.NET的反射机制,通过System.Reflection命名空间下的相关类,在运行时加载DLL文件,解析其中的类型和方法,再完成调用。和传统静态引用不同,动态调用不需要在编译期确定DLL的相关信息,所有操作都在程序运行阶段完成。
具体实现步骤
1. 加载DLL文件
首先需要使用Assembly类的LoadFrom方法加载目标DLL,这个方法需要传入DLL的完整路径,加载成功后会返回一个Assembly对象,后续的所有操作都基于这个对象展开。
using System;
using System.Reflection;
class Program
{
static void Main()
{
// DLL文件路径,这里替换为实际的DLL路径
string dllPath = @"D:\Test\TestDll.dll";
try
{
// 加载DLL文件
Assembly assembly = Assembly.LoadFrom(dllPath);
Console.WriteLine("DLL加载成功");
}
catch (Exception ex)
{
Console.WriteLine($"DLL加载失败:{ex.Message}");
}
}
}2. 获取目标类型
加载完DLL之后,需要获取要调用的类对应的Type对象,可以通过Assembly的GetType方法实现,需要传入类型的完整名称,格式是命名空间.类名。
// 假设DLL中有一个名为TestDll.Calculator的类,获取它的Type
Type calculatorType = assembly.GetType("TestDll.Calculator");
if (calculatorType == null)
{
Console.WriteLine("未找到目标类型");
return;
}3. 调用静态方法
如果要调用的是静态方法,可以直接通过MethodInfo获取方法信息,然后调用Invoke方法,第一个参数传入null即可。
// 获取静态方法Add,假设它有两个int参数,返回int
MethodInfo addMethod = calculatorType.GetMethod("Add", new Type[] { typeof(int), typeof(int) });
if (addMethod == null)
{
Console.WriteLine("未找到Add方法");
return;
}
// 调用静态方法,第一个参数为null,第二个是方法参数数组
object result = addMethod.Invoke(null, new object[] { 10, 20 });
Console.WriteLine($"静态方法Add调用结果:{result}");4. 调用实例方法
如果要调用实例方法,需要先创建类的实例,再通过实例调用方法。可以通过Activator.CreateInstance方法创建实例,如果有构造参数可以一并传入。
// 创建Calculator类的实例,假设无参构造
object calculatorInstance = Activator.CreateInstance(calculatorType);
// 获取实例方法Multiply,两个int参数,返回int
MethodInfo multiplyMethod = calculatorType.GetMethod("Multiply", new Type[] { typeof(int), typeof(int) });
if (multiplyMethod == null)
{
Console.WriteLine("未找到Multiply方法");
return;
}
// 调用实例方法,第一个参数是实例对象,第二个是参数数组
object multiplyResult = multiplyMethod.Invoke(calculatorInstance, new object[] { 5, 6 });
Console.WriteLine($"实例方法Multiply调用结果:{multiplyResult}");注意事项
- 路径问题:加载DLL时要确保路径正确,相对路径是相对于程序运行目录的,如果DLL不在运行目录,需要写绝对路径或者配置正确的相对路径。
- 依赖项处理:如果被调用的DLL还依赖其他DLL,需要把这些依赖的DLL也放到程序能够识别的路径下,否则会出现加载失败的情况。
- 异常处理:动态调用过程中很容易出现类型找不到、方法不存在、参数不匹配之类的错误,一定要做好异常捕获,避免程序直接崩溃。
- 类型转换:Invoke方法返回的是object类型,需要根据实际返回值类型做正确的转换,避免类型转换异常。
适用场景
动态调用DLL非常适合插件化开发,比如主程序定义好接口,不同的功能模块封装成DLL,运行时根据用户选择或者配置文件动态加载对应的DLL,实现功能的灵活扩展。另外在做一些热更新相关的功能时,也会用到这项技术,可以在不重启程序的情况下更新部分功能模块。
C#DLL动态调用ReflectionAssembly动态加载修改时间:2026-05-29 04:31:44