我已经检查了这些不同的解决方案,但似乎没有一个工作(它们似乎主要处理甚至无法调试dll):
Debug dynamically loaded assembly
Debug dynamically loaded assembly in Visual Studio .NET
我把pdb与dll并排(从它加载的确切位置).我还把那个dll的pdb文件放在正在进行加载的可执行文件旁边,但仍然没有骰子.我在Debug中编译,并已将所有配置设置为x86.有一点需要注意,如果我实际上将dll添加为Reference,则调试可视化工具会完美显示(但是,这是一个插件架构,并且exe不应该依赖于dll).
有任何想法吗?
[编辑]
事实证明,我不能只是添加插件作为参考,我必须在我的exe中实际实例化该类型的List才能正确显示,不确定发生了什么…
[编辑]
我做了这个展示行为的示例项目.我使用类似的代码来加载插件(虽然有趣的是,直接调用Assembly.LoadFile并通过反射调用方法似乎不会导致这种行为.我在这里压缩了示例项目:(其他人是否得到了相同的结果?)
http://dl.dropbox.com/u/64502227/PluginLoader.zip
[编辑]
又有趣的发展!我在exe旁边有一个Plugins文件夹,所有dll都在这里.目前,我正在将插件dll / pdb复制到exe目录和Plugins子目录中.如果我使用Assembly.LoadFile并在Plugins目录中使用dll,我将丢失我自己类型的List可视化工具.如果我在exe旁边加载dll,它可以工作,但为什么呢?
我所看到的:
解决方法
>从exe目录加载所有dll,而不是自己的目录.
解决方案B:
使用它来创建插件:
Plugin plugin = (Plugin)Activator.CreateInstance(assembly.FullName,"SamplePlugin.MyPlugin").Unwrap();
而不是这个:
Plugin plugin = (Plugin)Activator.CreateInstance(assembly.GetType("SamplePlugin.MyPlugin"));
我想第二行代码实际上只是在内部被第一行代码调用(例如,第一行必须按名称查找程序集,然后从中找到类型“SamplePlugin.MyPlugin”,然后展开()它返回它),但显然不是.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。