【发布时间】:2010-11-16 12:37:21
【问题描述】:
策略模式和委托模式(不是委托)有什么区别?
【问题讨论】:
标签: design-patterns delegation strategy-pattern
策略模式和委托模式(不是委托)有什么区别?
【问题讨论】:
标签: design-patterns delegation strategy-pattern
策略模式是针对常见软件问题的一种非常具体的设计解决方案。 策略模式意味着会有
委托与其说是一种模式,不如说是一种主体。委托意味着不是让单个对象负责所有事情,而是将职责委托给其他对象。这是一种常见技术的原因是,它通过减少耦合和增加内聚性来强制执行软件开发的两个更基本的原则。
说了这么多,不用担心模式。专注于原则,如果您觉得您的解决方案可以改进 - 查看模式,看看是否有更好的捕鼠器。如果你专注于模式而不是原则,你会发现自己迷失在所有模式中,为了实现模式而实现模式......
【讨论】:
“委托”并不是真正的设计模式,它更像是一种通用编程技术,其中组件 A 将任务(可能是任何类型的任务)委托给组件 B。委托可以在许多情况下使用。
另一方面,策略模式是一种特定模式,通常大量使用委托作为实现细节。
例如,您可以实现策略模式并使用
strategy.execute(x)
策略模式涉及策略接口的各种实现,并在运行时选择适当的实现。调用该实现的行为就是委托。
所以不是非此即彼,概念是互补的。
【讨论】:
这是一个想法:
代表模仿委托类(至少在我使用它们时,不确定这是否是规范的方式,但我通常是这样做的)。所以基本上,如果我有一个有多个入口点(方法)的类,并且我想在运行时更改实现,我会创建委托来实现相同的接口。
另一方面,如果我希望能够在运行时交换某个类的一部分,我将创建具有单个方法接口(例如 executeCalculation)的 Strategy 类,并使其成为包含类。
总而言之,策略包含一个行为,委托实现一组行为,您可以使用委托来实现策略。
【讨论】:
如果您的意思是策略模式与委托,例如作为参数传递的函数/lambda, 那么至少我知道需要为委托编译的类的开销更少。
实际上,我发现这个页面正在寻找有人给我他们关于仍然使用设计模式路由的好处的想法,因为 java 8 和 C# 现在都支持将函数作为参数传递
【讨论】: