Assembly.LoadFile 不推荐使用,因它仅加载单个DLL且不处理依赖、不参与默认加载上下文;应优先选用 Assembly.LoadFrom(兼容旧框架)或 AssemblyLoadContext(.NET Core+,支持卸载与隔离)。
Assembly.LoadFile 是 C# 中用于从指定文件路径加载程序集(DLL)的静态方法,但它不推荐在常规场景中使用,尤其不适合动态插件、热更新或依赖解析复杂的场景。它只加载单个文件,不处理依赖、不参与默认加载上下文,容易引发 FileNotFoundException 或类型无法识别等问题。
它直接按物理路径读取 DLL 文件并加载到当前进程,但不会自动加载其引用的其他程序集,也不会触发 GAC 或 probing 机制:
Assembly assembly = Assembly.LoadFile(@"C:\MyPlugin\MyLogic.dll");
Type t = assembly.GetType("MyLogic.Processor");
typeof(T).Assembly == assembly 判断相等性(因 LoadFile 加载的程序集与普通引用程序集视为不同实例)现代 .NET 推荐使用 AssemblyLoadContext 实现隔离、可卸载的动态加载:
context.Unload())Load(AssemblyName) 方法自定义查找逻辑相比 LoadFile,Assembly.LoadFrom 更可靠:
Assembly assembly = Assembly.LoadFrom(@"C:\MyPlugin\MyLogic.dll");
关键提醒:避免常见陷阱无论选哪种方式,都要注意:
System.* 或第三方库NativeAOT 或 P/Invoke,需保证运行时环境一致(如 x64/x86)assembly.GetExportedTypes() 确认类型是否存在且可访问基本上就这些。LoadFile 不复杂但容易忽略上下文问题,日常开发优先选 LoadFrom 或 AssemblyLoadContext,更稳也更可控。