设计模式之python版(二)--策略模式

策略模式:

应用特性:接收任意对象,然后对不同的对象去做相同的一件事情。

结构特性:策略模式其实是利用了多态的特性,使用固定的方法,但是把对象作为个体抽离出来了,对象在这里有点象抽离出来的配置文件的意思

UML:


#!/usr/bin/env python
#encoding: utf-8

class baseclass:
    def __init__(self):  
        pass
    
    def dosomething(self):
        pass
    
class newclass1(baseclass):
    def __init__(self):
        pass
    
    def dosomething(self, perfix):
        print perfix + ':dosomething1'
        
class newclass2(baseclass):
    def __init__(self):
        pass
    
    def dosomething(self, perfix):
        print perfix + ':dosomething2'
        
class newclass3(baseclass):
    def __init__(self):
        pass
    
    def dosomething(self, perfix):
        print perfix + ':dosomething3'
          

class setclass:
    def __init__(self,something):
        if 'newclass1' == something:
            self.classobj = newclass1()
        elif 'newclass2' == something:
            self.classobj = newclass2()
        elif 'newclass3' == something:
            self.classobj = newclass3()
        else:
            return None
        
    def dosomething(self,perfix):
        self.classobj.dosomething(perfix)

        
if '__main__' == __name__:
    class1 = setclass('newclass1')
    class2 = setclass('newclass2')
    class3 = setclass('newclass3')
    print class1.__class__
    print class2.__class__
    print class3.__class__
    class1.dosomething('class1')
    class2.dosomething('class2')
    class3.dosomething('class3') 

结果:

__main__.setclass
__main__.setclass
__main__.setclass
class1:dosomething1
class2:dosomething2
class3:dosomething3

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

上帝De助手

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值