<人人都懂设计模式>-状态模式
同样是水,固态,气态,液态的变化,是由温度引起。
引此为思考状态模式。
from abc import ABCMeta, abstractmethod
# 引入ABCMeta和abstractmethod来定义抽象类和抽象方法
"""
version 1.0
class Water:
def __init__(self, state):
self.__temperature = 25
self.__state = state
def set_state(self, state):
self.__state = state
def change_state(self, state):
if self.__state:
print("由 {} 变为 {}".format(self.__state.get_name(), state.get_name()))
else:
print("初始化为{}".format(state.get_name()))
self.__state = state
def get_temperature(self):
return self.__temperature
def set_temperature(self, temperature):
self.__temperature = temperature
if self.__temperature <= 0:
self.change_state(SolidState("固态"))
elif self.__temperature <= 100:
self.change_state(LiquidState("液态"))
else:
self.change_state(GaseousState("气态"))
def rise_temperature(self, step):
self.set_temperature(self.__temperature + step)
def reduce_temperature(self, step):
self.set_temperature(self.__temperature - step)
def behavior(self):
self.__state.behavior(self)
class State:
def __init__(self, name):
self.__name = name
def get_name(self):
return self.__name
@abstractmethod
def behavior(self, water):
pass
class SolidState(State):
def __init__(self, name):
super().__init__(name)
def behavior(self, water):
print("当前体温: {}".format(str(water.get_temperature())))
class LiquidState(State):
def __init__(self, name):
super().__init__(name)
def behavior(self, water):
print("当前体温: {}".format(str(water.get_temperature())))
class GaseousState(State):
def __init__(self, name):
super().__init__(name)
def behavior(self, water):
print("当前体温: {}".format(str(water.get_temperature())))
def test_state():
water = Water(LiquidState("液态"))
water.behavior()
water.set_temperature(-4)
water.behavior()
water.rise_temperature(18)
water.behavior()
water.rise_temperature(110)
water.behavior()
test_state()
"""
# version 2.0
class Context(metaclass=ABCMeta):
def __init__(self):
self.__states = []
self.__cur_state = None
self.__state_info = 0
def add_state(self, state):
if state not in self.__states:
self.__states.append(state)
def change_state(self, state):
if state is None:
return False
if self.__cur_state is None:
print("初始化为: {}".format(state.get_name()))
else:
print("由 {} 变为 {}".format(self.__cur_state.get_name(), state.get_name()))
self.__cur_state = state
self.add_state(state)
return True
def get_state(self):
return self.__cur_state
def _set_state_info(self, state_info):
self.__state_info = state_info
for state in self.__states:
if state.is_match(state_info):
self.change_state(state)
def _get_state_info(self):
return self.__state_info
class State:
def __init__(self, name):
self.__name = name
def get_name(self):
return self.__name
def is_match(self, state_info):
return False
@abstractmethod
def behavior(self, context):
pass
class Water(Context):
def __init__(self):
super().__init__()
self.add_state(SolidState("固态"))
self.add_state(LiquidState("液态"))
self.add_state(GaseousState("气态"))
self.set_temperature(25)
def get_temperature(self):
return self._get_state_info()
def set_temperature(self, temperature):
self._set_state_info(temperature)
def rise_temperature(self, step):
self.set_temperature(self.get_temperature() + step)
def reduce_temperature(self, step):
self.set_temperature(self.get_temperature() - step)
def behavior(self):
state = self.get_state()
if isinstance(state, State):
state.behavior(self)
def singleton(cls, *args, **kwargs):
instance = {}
def __singletone(*args, **kwargs):
if cls not in instance:
instance[cls] = cls(*args, **kwargs)
return instance[cls]
return __singletone
@singleton
class SolidState(State):
def __init__(self, name):
super().__init__(name)
def is_match(self, state_info):
return state_info < 0
def behavior(self, context):
print(", 我性格高冷, 当前体温: {}".format(context._get_state_info()))
@singleton
class LiquidState(State):
def __init__(self, name):
super().__init__(name)
def is_match(self, state_info):
return 0 <= state_info < 100
def behavior(self, context):
print("我性格温和, 当前体温: {}".format(context._get_state_info()))
@singleton
class GaseousState(State):
def __init__(self, name):
super().__init__(name)
def is_match(self, state_info):
return state_info >= 100
def behavior(self, context):
print("我性格热烈,当前体温: {}".format(context._get_state_info()))
def test_state():
water = Water()
water.behavior()
water.set_temperature(-4)
water.behavior()
water.rise_temperature(18)
water.behavior()
water.rise_temperature(110)
water.behavior()
test_state()
C:\Python36\python.exe C:/Users/Sahara/PycharmProjects/test/python_search.py 初始化为: 液态 我性格温和, 当前体温: 由 液态 变为 固态 , 我性格高冷, 当前体温: - 由 固态 变为 液态 我性格温和, 当前体温: 由 液态 变为 气态 我性格热烈,当前体温: Process finished with exit code
<人人都懂设计模式>-状态模式的更多相关文章
- <人人都懂设计模式>-中介模式
真正的用房屋中介来作例子, 好的书籍总是让人记忆深刻. class HouseInfo: def __init__(self, area, price, has_window, has_bathroo ...
- <人人都懂设计模式>-单例模式
这个模式,我还是了解的. 书上用了三种不同的方法. class Singleton1: # 单例实现方式1 __instance = None __is_first_init = False def ...
- <人人都懂设计模式>-装饰模式
书上,真的用一个人穿衣打拌来讲解装饰模式的呢. from abc import ABCMeta, abstractmethod class Person(metaclass=ABCMeta): def ...
- 14. 星际争霸之php设计模式--状态模式
题记==============================================================================本php设计模式专辑来源于博客(jymo ...
- 人人都懂区块链--pdf电子版学习资料下载
人人都懂区块链 21天从区块链“小白”到资深玩家电子版pdf下载 链接:https://pan.baidu.com/s/1TWxYv4TLa2UtTgU-HqLECQ 提取码:6gy0 好的学习资料需 ...
- [Head First设计模式]生活中学设计模式——状态模式
系列文章 [Head First设计模式]山西面馆中的设计模式——装饰者模式 [Head First设计模式]山西面馆中的设计模式——观察者模式 [Head First设计模式]山西面馆中的设计模式— ...
- 深入浅出设计模式——状态模式(State Pattern)
模式动机 在很多情况下,一个对象的行为取决于一个或多个动态变化的属性,这样的属性叫做状态,这样的对象叫做有状态的 (stateful)对象,这样的对象状态是从事先定义好的一系列值中取出的.当一个这样的 ...
- 24种设计模式--状态模式【State Pattern】
现在城市发展很快,百万级人口的城市一堆一堆的,那其中有两个东西的发明在城市的发展中起到非常重要的作用:一个是汽车,一个呢是...,猜猜看,是什么?是电梯!汽车让城市可以横向扩展,电梯让城市可以纵向延伸 ...
- C++设计模式——状态模式
前言 在实际开发中,我们经常会遇到这种情况:一个对象有多种状态,在每一个状态下,都会有不同的行为.那么在代码中我们经常是这样实现的. typedef enum tagState { state, st ...
随机推荐
- 8.9 NOIP模拟测试15 建设城市(city)+轰炸行动(bomb)+石头剪刀布(rps)
鉴于T3的惨烈程度,我决定先来颓篇题解. T1 建设城市(city) 挡板法+容斥 m个建设队分成n组,每组必须有一个,先不考虑上限,共有 C(m-1,n-1)种方案. 有i个组是超过k个的,容斥掉 ...
- ADB/Fastboot刷机
谷歌官方ADB/Fastboot等工具包下载地址(最新版/免.墙):WINDOWS :https://dl.google.com/android/repository/platform-tools-l ...
- python 获取日期以及时间
>>> import datetime >>> >>> i = datetime.datetime.now() >>> prin ...
- python开发--信息处理系统
#!/usr/bin/python card_list=[] #定义列表变量 def show_menu(): print("*" * 10) print("名片管理系统 ...
- markdown格式接口文档模板
源文件 https://files.cnblogs.com/files/bincoding/%E6%8E%A5%E5%8F%A3%E6%96%87%E6%A1%A3.zip 目录 测试接口 查询指定项 ...
- FWT-快速沃尔什变换
FWT-快速沃尔什变换 FWT有啥用啊 我们知道,FFT可以解决多项式的卷积,即 \[ C_k=\sum_{i+j=k}A_i*B_j \] 如果将操作符换一下,换成集合运算符 比如 \[ C_k=\ ...
- c++性能测试工具:计算时间复杂度
有时候除了测量算法的具体性能指数,我们也会希望测试出算法的时间复杂度,以便我们对待测试的算法的性能有一个更加直观的了解. 测量时间复杂度 google benchmark已经为我们提供了类似的功能,而 ...
- DirectX:Vector
Tag DirectX下的博客主要用于记录DirectX的学习过程,主要参考<DirectX 12 3D 游戏实战开发>. Vector in DirectX Shader的编写离不开数学 ...
- SCCM+WSUS的方式分发补丁
简单来说,System Center Configuration Manager(SCCM/ConfigMgr)由SMS(Systems Management Server)发展而来,其作为一款针对企 ...
- Python爬虫实战之爬取糗事百科段子【华为云技术分享】
首先,糗事百科大家都听说过吧?糗友们发的搞笑的段子一抓一大把,这次我们尝试一下用爬虫把他们抓取下来. 友情提示 糗事百科在前一段时间进行了改版,导致之前的代码没法用了,会导致无法输出和CPU占用过高的 ...