gpt4 book ai didi

xamarin.forms - 哪个 IoC 容器更适合 Prism.Forms

转载 作者:行者123 更新时间:2023-12-03 11:33:04 25 4
gpt4 key购买 nike

我在开始新的Prism.Forms项目,我想知道各种 IoC 中的哪一个容器( AutofacDrylocNinjectUnity )最好继续使用。

我不知道这是否属实,但我在某处读到 Unity 不再处于积极开发状态,因为这和 MEF是唯一的IoC我曾经使用过的容器我不确定它是否适合我。

同时,我对Autofac知之甚少或一无所知。 , DrylocNinject .

请在任何建议中保持客观,提供您认为某个比其他更好的原因,而不是简单地“我使用 xxx”;我想做出明智的决定。

最佳答案

我能做的最好的事情就是按照目前的情况排列事实。

注意:自从我在 2017 年第一次回答这个问题以来,发生了很多变化。以下信息一直在更新,应该可以帮助您对项目做出决定。但是请注意,您现在还可以使用 Prism.Container.Extensions,因为它支持抽象许多非常强大的注册方法,包括工厂,以及将单个实现注册为不同服务的单例的能力。可以在那里添加额外的容器。其他文档可以在 https://prismplugins.com 中找到。

支持的容器

这些是 Prism 团队正式发货的容器

DryIoc

这是我使用和推荐最多的容器。它正在积极开发中,速度非常快,并且与 Prism 的当前版本配合得很好。同样重要的是,当我有疑问或问题时,维护者会非常迅速地解决问题或回答我的问题。 Dadhi 也非常擅长主动为 Prism 集成提供增强功能。出于所有这些原因,我继续推荐容器。与 Unity 不同的是,API 往往非常稳定,我还没有遇到过将 DryIoc 更新到超出特定 Prism 版本目标的问题。

统一容器

不要与 Unity 游戏开发平台混淆。这是最受欢迎的容器,因为它是 Brian 使用多年的容器,并且它是模板中第一个(并且很长一段时间内唯一)可用的容器。它已经有一段时间没有维护了,但是该项目确实有一个新的维护者。值得注意的是,Unity 5 中有许多重大更改,这使得使用 Prism 6.3 升级到 Unity 5 变得不可能。然而,Prism 7 的所有平台上的 Prism 都更新到了 Unity 5。就其基准性能而言,Unity 也处于平均水平。对于从 Prism 6.X 升级到 Prism 7 的用户,请注意您应该卸载对 Unity 或 Common Service Locator 的任何引用,然后更新 Prism.Unity.Forms,它现在面向 Unity.Container NuGet 包而不是 Unity NuGet 包。您还应该注意,针对比 Prism 所针对的更新版本的 Unity 可能会破坏您的应用程序,因为 Unity 引入了许多重大更改,但没有从 Minor Patch 到 Minor Patch 的解释或文档。

非官方支持

这些是提供非官方软件包的容器。这些可能对您有用,也可能不适合,风险由您自行承担。

Microsoft.Extensions.DependencyInjection

Prism 需要某些特性,例如 Microsoft DependencyInjection 模式不支持的可变性和命名服务。然而,有一个实现可以为 Prism.Container.Extensions 项目中的所有 Prism 应用程序/平台提供通用支持。

生命周期结束/弃用的容器

虽然这些容器多年来已在许多项目中使用,但 Prism 团队不再支持以下容器。

汽车制造商

尽管很受欢迎,但我通常会建议不要使用容器。人们似乎对 API 感到非常困惑。在 Prism 6.3 中,它的实现非常糟糕。可悲的是,为了提高性能,Autofac 团队非常坚决地决定让容器不可变。从 Prism 7.1 开始,Prism 正式放弃了对这个容器的支持。

宁捷

Ninject 长期以来一直是使用最少的容器之一。随着团队转向支持 netstandard,它在 7.0 中从 Prism.Forms 中删除。虽然 Ninject 3.3 在技术上确实附带了 netstandard2.0 api,但它与 Xamarin 目标不兼容。它目前也处于非常不健康的状态,从 2017 年 11 月发布了最新的 3.3 版本,从 2016 年 8 月发布了最新的 4.0 预览版。

更新

值得注意的是,从 Prism 7 的 Preview 5 开始,我们已经对容器进行了抽象。这最终将使在您选择的容器之间切换变得更加容易,因为 API 在如何注册您的服务和 View 方面完全相同。您仍然可以通过扩展方法访问 Container,在 Autofac 的情况下,您可以访问 ContainerBuilder,以便您可以完成更复杂的注册。

// Prism 6.X way of Registering Services
protected override void RegisterTypes()
{
// Container Specific Registrations

// Autofac
Builder.RegisterType<DebugLogger>().As<ILoggerFacade>().SingleInstance();

// DryIoc
Container.Register<ILoggerFacade, DebugLogger>(reuse: Reuse.Singleton,
ifAlreadyRegistered: IfAlreadyRegistered.Replace);

// Ninject
Container.Bind<ILoggerFacade>().To<DebugLogger>().InSingletonScope();

// Unity
Container.RegisterType<ILoggerFacade, MCAnalyticsLogger>(new ContainerControlledLifetimeManager());
}

// Unified API in Prism 7
protected override void RegisterTypes(IContainerRegistry containerRegistry)
{
containerRegistry.RegisterSingleton<ILoggerFacade, DebugLogger>();
}

同样重要的是要记住,虽然 Prism 的 IoC 抽象使拥有更统一的 API 变得更容易,但这并没有消除您直接与底层容器交互的能力。要访问底层容器,您只需调用 GetContainer 扩展方法,并且您将能够执行 Prism 的 IoC 抽象不直接支持的任何更复杂的操作。

更新 2

Prism 7.2 引入了一些围绕 IoC 抽象的 API 更改。值得注意的是,总的来说,这些更改不应影响大多数用户。但是,如果使用引用旧版 Prism 的其他库,您可能会遇到二进制不兼容问题。

国际奥委会的变化包括:
  • 流畅的 API
  • 检查服务是否已注册的能力
  • 添加了允许临时服务和单例服务成为命名服务的方法
  • 添加了使用指定实例解析服务的功能。
  • 关于xamarin.forms - 哪个 IoC 容器更适合 Prism.Forms,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43664455/

    25 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com