如果目标程培基态序集是可执行程序,则可以令新建的域执行该代码,此时,在代码执行中突然卸载域,会从执行线程上引发AppDomainUnloadException异常。
跨应用程序域访问不是一种好的设计思路。
//Entry Point :[DllImport("TEST.dll", PreserveSig = true, CharSet = CharSet.Ansi, CallingConvention = CallingConvention.StdCall, EntryPoint = "碰派GetName"笑梁贺)]
public static extern short GetName(ushort adr)
//AssemblyLoad :
Assembly ass = Assembly.LoadFile(dllPath)
Object instance = ass.CreateInstance(className)//创建一个渣空实例
Type type = ass.GetType(className)
public string GetName(int index)
{
object[] args = { index }
object obj = type.InvokeMember(methodName, BindingFlags.Default | BindingFlags.InvokeMethod, null, instance, args)
return (string)obj
}
我先说下你想要裂丛毁的结果,你把Assembly.LoadFrom换成Assembly.LoadFile即可。另外,你既然能够在你的应用中使用Assembly.LoadFrom这样的方法,那test1.dll他们的路径就是已知的了,何必还要通过反射程序集内部方法来获取它的Location呢?
如果你是将test1.dll注册到了全局环境中,那么我郑裤建议你不要使用LoadFrom和LoadFile,改用Load方法:将test1和test2通过版本号或者公钥(PublicKey)加以区别,然后用Load方肆备法调用。调用参数类似于:“程序集名,Version=版本1,culture=区域信息1,PublicKeyToken=公钥1”,这是微软标准的做法。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)