美文网首页Android深入
为什么我们在 Android 中使用像 Dagger 这样的依赖

为什么我们在 Android 中使用像 Dagger 这样的依赖

作者: BlueSocks | 来源:发表于2022-08-30 14:19 被阅读0次

    我们可能会也可能不会在项目中使用依赖框架。在这篇博客中,我们将讨论为什么我们需要一个依赖框架以及为什么在我们的项目中使用它是有用的。

    在这里,我们可以假设这是一个面试问题。

    问题: “为什么我们在 Android 中使用像 Dagger 这样的依赖注入框架?”

    在这篇文章中,我们将通过以下内容来回答这个问题:

    • 为什么我们在 Android 中使用像 Dagger 这样的依赖注入框架?
    • 我们如何将我们的配置提供给框架?
    • 结论

    注意:本文不是关于学习 Dagger 或任何依赖注入框架,但是,这将帮助您了解它如何对 Android 项目有用,并且您将能够说服任何人根据要求使用依赖注入框架。

    让我们开始吧。

    为什么我们在 Android 中使用像 Dagger 这样的依赖注入框架?

    考虑一下,当我们必须在项目中创建大量依赖于许多其他对象的对象时,当项目变得更大时,这变得很困难。随着代码库的增加,我们可能需要一些良好的外部支持来管理它。这是我们使用依赖框架的用例之一。我们稍后将在本博客中了解其他用例。 让我们通过一个例子来理解这个用例。

    考虑一个示例,我们有两个活动,活动 A 和活动 B。两者都需要一个对象 Downloader,其中 Downloader 将需要请求。现在,请求将取决于 Executor 和 HTTPClient。

    在这里,我们首先创建一个 Executor 和 HttpClient 对象,并将它们传递给请求对象,例如,

    val executor = Executor()
    val client = HttpClient()
    val request = Request(executor, client)
    

    然后我们在下载器中传递请求,

    val downloader = Downloader(request)
    

    这就是我们如何为 Downloader 创建一个对象。现在,考虑到我们需要在两个活动(A 和 B)中使用它,我们需要一次又一次地编写所有这 4 行。

    为了减少编写此代码,我们可以一次又一次地创建一个工厂类并使用以下方法创建下载器:

    val downloader = DownloaderFactory.create()
    DowloaderFactory 在哪里,
    
    object DownloaderFactory{
        fun create():Downloader{
            val executor = Executor()
            val client = HttpClient()
            val request = Request(executor, client)
            return Downloader(request)
        }
    }
    

    这将使任务变得容易。

    依赖注入建立在控制反转的概念之上,即一个类应该从外部获取其依赖关系。简而言之,任何类都不应该实例化另一个类,而应该从配置类中获取实例。

    现在,考虑一下,如果我们只是为某个框架提供某种配置,例如创建对象的方式、范围(生命周期),那么该框架会为我们创建这些类型的工厂类。我们的任务会变得很容易。我们只需要编写一些代码来为框架提供配置,框架就会为我们创建工厂类。我们会使用它。

    例如,假设我们在我们的地方举办了一个生日聚会,我们需要一个蛋糕。所以,自己做蛋糕需要付出很多努力和完美。我们可以向面包店下订单,面包店将充当框架,接受我们的指示,然后将蛋糕交付给我们。在这里,我们是消费者。

    现在,让我们看看如何为框架提供配置。

    我们如何将我们的配置提供给框架?

    使用框架可以减少我们编写的大量代码。所以,通俗的讲,我们给框架配置,比如创建对象的方式,对象的作用域(生命周期),这样框架就可以为我们创建依赖,然后消费者可以根据配置获取依赖我们提供了。

    现在,让我们考虑Dagger这里的框架示例,

    Dagger 在为我们生成代码的注释处理的基础上工作。Dagger 只需要我们通过创建一些类和接口并使用注释来提供的配置。

    为此,我们主要使用四个注释,

    @Module, @Provides,@Component@Inject.

    带有注解的类@Module负责提供可以注入的对象。这样的类定义了用 注释的方法@Provides。这些方法返回的对象可用于依赖注入。

    @Inject注释用于定义消费者内部的依赖关系。

    @Component被注释到一个接口,Dagger 使用@Component并生成相应的组件类,作为模块(对象的提供者)和消费者之间的桥梁,以提供所需的依赖关系。它从模块类中获取所需的依赖项。

    此外,创建具有应用程序范围(应用程序生命周期)或活动范围(活动生命周期)的对象变得容易。该框架还有许多其他方面可以帮助我们。

    如果您想详细了解 Dagger,请参阅此博客

    Dagger 只需要我们为所需的依赖项提供配置,然后它会使用我们通过内部生成代码提供的注解来处理它。

    结论

    我们应该使用依赖框架,原因如下:

    • 它帮助我们轻松管理复杂的依赖关系。
    • 它使我们能够从外部传递所有依赖项,从而使单元测试变得容易,以便我们可以轻松地使用模拟对象。
    • 它可以轻松管理对象的范围(生命周期)。

    这就是为什么我们需要在 Android 中使用像 Dagger 这样的依赖注入框架。

    文章来源:https://blog.mindorks.com/why-do-we-use-the-dependency-injection-framework-in-android

    相关文章

      网友评论

        本文标题:为什么我们在 Android 中使用像 Dagger 这样的依赖

        本文链接:https://www.haomeiwen.com/subject/iuvlnrtx.html