- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在学习依赖注入(inject)和控制反转,我想我开始理解它是如何工作的:
如果一切正确,我是否可以不再在我的对象中使用我所谓的“引用方法”?
这就是我所说的引用方法。假设我有两个模型用于家庭和家庭成员。我发现创建引用与该模型相关的对象的方法非常有帮助。在下面的示例中,当调用 $family->members()
时,我可以快速访问所有家庭成员。但是,这意味着我的 family
对象正在实例化 family_member
类……这不会违反 IoC 规则吗?
如果 family_member
类具有超出 family
类范围的依赖项怎么办?在这里输入将非常有用!
<?php
class family
{
public $id;
public function members()
{
// Return an array of family_member objects
}
}
class family_member
{
public $family_id;
public $first_name;
public $last_name;
public $age;
}
最佳答案
免责声明:我只是自己学习 DI。对答案持保留态度。
依赖注入(inject)只是注入(inject)依赖。如果您的面向对象设计导致 Family
对象负责创建 Member
的实例,那么一定要让 Family
对象创建Member
,因为在那种情况下,Member
不再被视为 Family
的依赖项,而是 责任。因此:
class Family
{
/**
* Constructor.
*
* Since you have decided in your OO design phase that this
* object should have the responsibility of creating members,
* Member is no longer a dependency. MySQLi is, since you need
* it to get the information to create the member. Inject it.
*
*/
public function __construct($id, MySQLi $mysqli)
{
$this->id = $id;
$this->mysqli = $mysqli;
}
/**
* Query the database for members data, instantiates them and
* return them.
*
*/
public function getMembers()
{
// Do work using MySQLi
}
}
但是如果你仔细想想,Family
真的应该有创建Member
的责任吗? 更好的设计是有另一个对象,例如 FamilyMapper
创建 Family
及其成员。像这样:
class FamilyMapper
{
/**
* Constructor.
*
* A better OO design, imho is using the DataMapper pattern.
* The mapper's responsibility is instantiating Family,
* which means it's going to have to connect to the database,
* which makes MySQLi its dependency. So we inject it.
*
*/
public function __construct(MySQLi $mysqli)
{
$this->mysqli = $mysqli;
}
public function findByID($familyID)
{
// Query database for family and members data
// Instantiate and return them
}
}
class Family
{
/**
* Constructor.
*
* Family is an object representing a Family and its members,
* along with methods that *operate* on the data, so Member
* in this OO design is a dependency. Inject it.
*
*/
public function __construct($id, MemberCollection $members)
{
$this->id;
$this->members;
}
public function getMembers()
{
return $this->members;
}
}
使用此模式,您的域对象及其方法(可能包含业务逻辑)将与您的数据访问代码分离。这就是依赖注入(inject)的好处 - 它迫使您重新考虑您的 OO 设计,以便您最终得到更清晰的代码。
许多人认为使用依赖注入(inject)意味着不使用工厂等。 这是错误的!依赖注入(inject)只是注入(inject)依赖。您也可以对工厂对象使用依赖注入(inject),方法是将依赖注入(inject)工厂而不是让工厂实例化自己的依赖。
有用的链接:
同样,对下面的内容持保留态度。
另请注意,依赖注入(inject) 和依赖注入(inject)容器 之间存在差异。第一个是注入(inject)依赖项而不是让对象自己创建依赖项的简单概念(这会导致非常高的耦合)。我们从上面的例子中看到了这一点。
后者是处理依赖注入(inject)的框架/库的术语,因此您不必进行手动注入(inject)。容器的职责是连接依赖项,因此您不必做脏活累活。这个想法是你定义一个依赖注入(inject)配置,它告诉容器 Foo
对象有什么依赖,以及如何注入(inject)它们。容器读取文档并为您执行注入(inject)。 Pimple、SimpleDIC 等 DIC 库就是这样做的。
您可以将依赖注入(inject)容器与工厂进行比较,因为两者都是创建对象,其唯一职责是创建对象。虽然工厂通常是专门的(即 FamilyMemberFactory
创建 MemberInterface
的实例),但依赖注入(inject)容器更为通用。有人说使用依赖注入(inject)容器可以让您摆脱对工厂的需求,但您应该记住,这意味着您必须创建和维护依赖注入(inject)配置文件,这可能是数千行 XML/PHP 行。
希望对您有所帮助。
关于php - 了解 IoC、DI 和引用方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7881378/
我开始认真考虑使用 IoC 容器会引发创建过度设计的解决方案(至少它会促使我尝试使用各种不必要的功能:)。 是时候将我的“IoC”反模式列表与社区列表同步了。 我短暂的经验告诉我们,在启动时每个应用程
我一直在阅读有关控制反转框架的内容,而我只是在玩弄这个问题:“我到底为什么需要一个框架来做到这一点?” 不要误解我的问题...该模式是我们程序员经常使用的,但是...一个功能齐全的框架可以做到这一点?
想要改进这篇文章?提供这个问题的详细答案,包括引文和解释为什么你的答案是正确的。没有足够细节的答案可能会被编辑或删除。 我正在尝试确定是否需要付出额外的努力来封装我的 IoC 容器。经验告诉我,我应该
有人建议我,在使用 IOC 容器时,我应该改变这个: class Foobar: IFoobar, IDisposable {}; 进入这个: interface IFoobar: IDisposab
《畜牧代码》播客第 68 期有人,http://herdingcode.com/herding-code-68-new-year-shenanigans/ ,表示 IOC 容器不适合使用 Python
我们正在使用 NInject 框架在我们的应用程序中实现 IoC/DI。我们有具有内部方法的内部类。要实现 IoC/DI,我们必须提取接口(interface)。但是如果我们在一个内部类中只有内部方法
Spring IOC 相关接口分析 1.BeanFactory Spring 中 Bean 的创建是典型的工厂模式,这一系列的 Bean 工厂,即 IOC 容器,为开发者管理对象之间的依赖关系提供了很
MEF is not an IoC container .不过好像是差不多 一个 IoC 容器。似乎我可以很容易地让 MEF 表现得像一个 IoC 容器(见下面的例子),而且让 MEF 成为一个完整的
只是想继续了解 IOC 的原则。 Q1:静态方法 - 具有静态辅助方法的实用程序类是否应该与 IOC 连接? 例如,如果我有一个带有许多静态方法的 HttpUtils 类,我是否应该尝试通过 IOC
众所周知,在asp.net Startup 类中有一个方法ConfigureServices,我们可以添加自定义服务。服务通过依赖注入(inject)提供。 ASP.NET Core includes
所以..我一直在深入研究 IoC 容器和服务定位器。 我认为 IoC 容器是 IoC 容器,而不是服务定位器,因为 您使用它的方式。您将服务定位器传递给需要依赖项的类,然后通过容器检索依赖项。另一方面
阅读许多有关这三个成语之间差异的帖子。但是比较困惑,然后我遇到了这篇文章: http://martinfowler.com/articles/injection.html 只是想看看我是否做对了。如果
我正在寻找用于 asp.net webapi 的 ioc 容器。我们正在寻找的几个关键功能如下 自定义生命周期 对网络请求生命周期的内置支持 在管理依赖项注册方面与 Web API 的良好集成。 最佳
我很难跟随 FP。当人们说“更惯用的风格”时,我必须明白:99% 的 Java 库不适用于 Kotlin 和 Scala 的 FP 惯用风格,对吧?好吧,我需要 Spring Boot 来快速启动 V
目录 1、Spring 1.1、简介 1.2、优点 1.3、组成 1.4、扩展 2、IO
重要提示:请注意,我并不是说单例具有私有(private)构造函数和静态实例变量(或有人建议使用静态类),而是单例在应用程序生命周期内从控制容器的反转返回相同的实例。 许多容器默认使用较短的生命周期。
Closed. This question needs to be more focused。它当前不接受答案。 想要改善这个问题吗?更新问题,使它仅关注editing this post的一个问题。
松耦合当然很棒,但我经常想知道使用 IoC 容器(例如 CaSTLe Windsor)动态连接的开销对紧耦合系统有什么影响? 我知道详细的答案将取决于 IoC 的用途,但我真的只是想了解 IoC 工作
我正在努力让 IOC 在远程处理场景中工作。我将我的应用程序服务器设置为发布通过 XML 配置的服务(SingleCall)。 众所周知,这就像这样: RemotingConfiguration.Co
我使用 IoC (DI) 方法并且通常有参数,这些参数由最低层(数据库层等)从配置设置(即连接字符串、静态值等)中读取。最好的方法是什么? 直接在这个最底层读取,即: string sendGridA
我是一名优秀的程序员,十分优秀!