在处理dll动态加载时,遇到事件不会处理。特记录下这篇,供后期查看。
dll代码:
namespace ClassLibrary
{
public class Class1
{
public delegate void callback_delegate(string str);
public event callback_delegate callback_event;
public void Fun5(string str)
{
ShowCallBack();
}
public void ShowCallBack()
{
if(callback_event != null)
{
callback_event("aaaaaaaaa");
}
}
}
}
调用代码:
Assembly assembly = Assembly.LoadFile(m_dll_path);
Type type = assembly.GetType("ClassLibrary.Class1");
//带参数构造函数 Object obj = Activator.CreateInstance(type,new object[]{"1"});
Object obj = Activator.CreateInstance(type);
BindingFlags mybindingFlags = BindingFlags.Instance | BindingFlags.Public;
EventInfo eventInfo = obj.GetType().GetEvent("callback_event", mybindingFlags);
//绑定自己的方法
var mycallback = typeof(Form1).GetMethod("ShowMsg",BindingFlags.Static|BindingFlags.NonPublic);
Delegate del = Delegate.CreateDelegate(eventInfo.EventHandlerType,null, mycallback);
eventInfo.AddEventHandler(obj,del);
MethodInfo methodInfo = type.GetMethod("Fun5");
string ret = methodInfo.Invoke(obj, new object[] { "123"}) as string;
解决DLL动态加载时的事件处理问题,
文章介绍了在C#中处理DLL动态加载时遇到的事件处理难题。通过示例展示了如何在DLL中定义事件和委托,以及在调用代码中如何绑定自己的方法到DLL事件上,确保回调的正确执行。关键步骤包括使用`Assembly.LoadFile`加载DLL,通过`Activator.CreateInstance`创建实例,使用`GetEvent`获取事件信息,以及利用`Delegate.CreateDelegate`创建委托并添加到事件处理器。
1346

被折叠的 条评论
为什么被折叠?



