设计模式-策略模式

策略模式

把一系列算法封装起来,使得他们可相互替换,是的算法可独立与他的客户端而变化

from abc import ABCMeta,abstractmethod

#抽象策略
class Stretrgy(object):
	__metaclass__ = ABCMeta

	def excute(self, data):
		pass
#----------------具体策略----------------
class FirstStretrgy(Stretrgy):
	def excute(self, data):
		print "执行快速策略%s" %data


class SlowStretrgy(Stretrgy):
	def excute(self, data):
		print "执行慢速策略%s" % data
#----------------具体策略----------------

#上下文 把策略对象和数据对象封装起来
class Context(object):
	def __init__(self,data, stretrgy):
		self.stretrgy = stretrgy
		self.data = data

	def do_stretrgy(self):
		self.stretrgy.excute(self.data)

	def set_stretrgy(self, stretrgy):
		self.stretrgy = stretrgy	#更换策略

#client
data = "11111"
st = FirstStretrgy()
c = Context(data,st)
c.do_stretrgy()
st_2 = SlowStretrgy()
c.set_stretrgy(st_2)
c.do_stretrgy()

优点:

  • 消除了一些条件语句
    缺点
  • 客户需要了解策略
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值