C#创建DLL,并实现动态加载

建立C# DLL工程

添加新项目->Visual C#->类库;
增加类库函数如下:

namespace DoNetDLL
{
    public class DoNetDllClass
    {
        public UInt32 SeedAndKeyFunc(UInt32 level, UInt32 len, byte[] seed, byte[] key)
        {
        	key[0] = 0x11;
        	key[1] = 0x11;
        	key[2] = 0x11;
        	key[3] = 0x11;
            return 0;
        }
    }
}

引用代码块

这里主要解决动态调用问题,即当有多个DLL时,在不同的场景需要调用不同的DLL来实现。
引用代码块主要涉及传参类型,否则会报参数错误;
定义Type[] params_type来存储传参类型信息,UInt32Byte数组分别使用Type.GetType("System.UInt32")Type.GetType("System.Byte[]")类型;实际参数定义Object[] params_obj来存储,对应配置即可。
注意Type.GetType中的类型必须是System空间下的类型。
运行代码,可以看到key已经有带出数据了。

byte[] seed = new seed[6];
byte[] key = new key[6];
UInt32 level27 = 2, reqLen27 = 4;
// 加载DLL,SecurityDllPath为DLL的pathName->C:/SecurityDLL.dll
Assembly assembly = Assembly.LoadFile(SecurityDllPath);
// 获取类型, 传入函数所属namespace和class 
Type type = assembly.GetType("DoNetDLL.DoNetDllClass");
// 创建对象实例,传入函数所属namespace和class   
object instance = assembly.CreateInstance("DoNetDLL.DoNetDllClass");
// 传参调用   
Type[] paramsTypes = new Type[4];
paramsTypes[0] = Type.GetType("System.UInt32");
paramsTypes[1] = Type.GetType("System.UInt32");
paramsTypes[2] = Type.GetType("System.Byte[]");
paramsTypes[3] = Type.GetType("System.Byte[]");
Object[] paramsValue = new Object[4];
paramsValue[0] = level27;
paramsValue[1] = reqLen27;
paramsValue[2] = seed;
paramsValue[3] = key;
//执行DoNetDllFunc方法   
object value = type.GetMethod("SeedAndKeyFunc", paramsTypes).Invoke(instance, paramsValue);
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C#中嵌入DLL并调用其中的函数,可以使用DllImport属性和LoadLibrary函数。 以下是实现的步骤: 1. 创建一个C#项目, 添加一个类,并引入System.Runtime.InteropServices命名空间。 2. 使用DllImport属性声明要调用的DLL和其中的函数。例如: ```csharp [DllImport("user32.dll")] public static extern int MessageBox(IntPtr hWnd, string text, string caption, int options); ``` 3. 在代码中使用该函数。例如: ```csharp MessageBox(IntPtr.Zero, "Hello World!", "Greeting", 0); ``` 4. 如果要嵌入DLL,可以使用LoadLibrary函数加载DLL,并获取其中的函数地址。例如: ```csharp IntPtr handle = LoadLibrary("mydll.dll"); IntPtr funcPtr = GetProcAddress(handle, "myfunc"); ``` 5. 然后可以使用Marshal.GetDelegateForFunctionPointer方法将函数地址转换为委托类型,并使用该委托调用函数。 完整代码示例: ```csharp using System; using System.Runtime.InteropServices; class Program { [DllImport("user32.dll")] public static extern int MessageBox(IntPtr hWnd, string text, string caption, int options); [DllImport("mydll.dll")] public static extern int myfunc(int arg); [DllImport("kernel32.dll")] public static extern IntPtr LoadLibrary(string path); [DllImport("kernel32.dll")] public static extern IntPtr GetProcAddress(IntPtr handle, string symbol); static void Main() { MessageBox(IntPtr.Zero, "Hello World!", "Greeting", 0); IntPtr handle = LoadLibrary("mydll.dll"); IntPtr funcPtr = GetProcAddress(handle, "myfunc"); var myFunc = Marshal.GetDelegateForFunctionPointer<myfuncDelegate>(funcPtr); int result = myFunc(42); Console.WriteLine($"Result: {result}"); } [UnmanagedFunctionPointer(CallingConvention.Cdecl)] delegate int myfuncDelegate(int arg); } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值