This commit is contained in:
周伟
2022-05-11 19:04:14 +08:00
parent 9440ac7291
commit d9c5ffd627
826 changed files with 0 additions and 481675 deletions

View File

@@ -25,13 +25,7 @@
<meta name="generator" content="Hexo 4.2.0">
</head>
<body>
<div class="book-container">
<div class="book-sidebar">
@@ -55,373 +49,190 @@
<li><a href="/" class="current-tab">首页</a></li>
</ul>
<ul class="uncollapsible">
<li><a href="../">上一级</a></li>
</ul>
<ul class="uncollapsible">
<li>
<a href="/专栏/白话设计模式 28 讲(完)/00 生活中的设计模式:启程之前,请不要错过我.md.html">00 生活中的设计模式:启程之前,请不要错过我.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/01 监听模式:坑爹的热水器.md.html">01 监听模式:坑爹的热水器.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/02 适配模式:身高不够鞋来凑.md.html">02 适配模式:身高不够鞋来凑.md.html</a>
</li>
<li>
<a class="current-tab" href="/专栏/白话设计模式 28 讲(完)/03 状态模式:人与水的三态.md.html">03 状态模式:人与水的三态.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/04 单例模式:你是我生命的唯一.md.html">04 单例模式:你是我生命的唯一.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/05 职责模式:我的假条去哪了.md.html">05 职责模式:我的假条去哪了.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/06 中介模式:找房子问中介.md.html">06 中介模式:找房子问中介.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/07 代理模式:帮我拿一下快递.md.html">07 代理模式:帮我拿一下快递.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/08 装饰模式:你想怎么穿就怎么穿.md.html">08 装饰模式:你想怎么穿就怎么穿.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/09 工厂模式:你要拿铁还是摩卡.md.html">09 工厂模式:你要拿铁还是摩卡.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/10 迭代模式:下一个就是你了.md.html">10 迭代模式:下一个就是你了.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/11 组合模式:自己组装电脑.md.html">11 组合模式:自己组装电脑.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/12 构建模式:想要车还是庄园.md.html">12 构建模式:想要车还是庄园.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/13 克隆模式:给你一个分身术.md.html">13 克隆模式:给你一个分身术.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/14 策略模式:怎么来不重要,人到就行.md.html">14 策略模式:怎么来不重要,人到就行.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/15 命令模式:大闸蟹,走起!.md.html">15 命令模式:大闸蟹,走起!.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/16 备忘模式:好记性不如烂笔头.md.html">16 备忘模式:好记性不如烂笔头.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/17 享元模式:颜料很贵必须充分利用.md.html">17 享元模式:颜料很贵必须充分利用.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/18 外观模式:学妹别慌,学长帮你.md.html">18 外观模式:学妹别慌,学长帮你.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/19 访问模式:一千个读者一千个哈姆雷特.md.html">19 访问模式:一千个读者一千个哈姆雷特.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/20 生活中的设计模式:与经典设计模式的不解渊源.md.html">20 生活中的设计模式:与经典设计模式的不解渊源.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/21 生活中的设计模式:那些未完待续的设计模式.md.html">21 生活中的设计模式:那些未完待续的设计模式.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/22 深入解读过滤器模式:制作一杯鲜纯细腻的豆浆.md.html">22 深入解读过滤器模式:制作一杯鲜纯细腻的豆浆.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/23 深入解读对象池技术:共享让生活更便捷.md.html">23 深入解读对象池技术:共享让生活更便捷.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/24 深入解读回调机制:把你技能亮出来.md.html">24 深入解读回调机制:把你技能亮出来.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/25 谈谈我对设计模式的理解.md.html">25 谈谈我对设计模式的理解.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/26 谈谈我对设计原则的思考.md.html">26 谈谈我对设计原则的思考.md.html</a>
</li>
<li>
<a href="/专栏/白话设计模式 28 讲(完)/27 谈谈我对项目重构的看法.md.html">27 谈谈我对项目重构的看法.md.html</a>
</li>
</ul>
</div>
</div>
<div class="sidebar-toggle" onclick="sidebar_toggle()" onmouseover="add_inner()" onmouseleave="remove_inner()">
<div class="sidebar-toggle-inner"></div>
</div>
<script>
function add_inner() {
@@ -431,9 +242,6 @@
inner.classList.add('show')
}
function remove_inner() {
let inner = document.querySelector('.sidebar-toggle-inner')
@@ -441,9 +249,6 @@
inner.classList.remove('show')
}
function sidebar_toggle() {
let sidebar_toggle = document.querySelector('.sidebar-toggle')
@@ -473,9 +278,6 @@
}
function open_sidebar() {
let sidebar = document.querySelector('.book-sidebar')
@@ -499,13 +301,7 @@ function hide_canvas() {
overlay.classList.remove('show')
}
</script>
<div class="off-canvas-content">
<div class="columns">
@@ -575,23 +371,14 @@ function hide_canvas() {
<pre><code class="language-python">class Water:
&quot;水(H2O)&quot;
def __init__(self, state):
self.__temperature = 25
self.__state = state
def setState(self, state):
self.__state = state
def changeState(self, state):
if (self.__state):
@@ -605,15 +392,9 @@ function hide_canvas() {
print(&quot;初始化为&quot;, state.getStateName())
self.__state = state
def getTemperature(self):
return self.__temperature
def setTemperature(self, temperature):
self.__temperature = temperature
@@ -629,111 +410,60 @@ function hide_canvas() {
else:
self.changeState(GaseousState(&quot;气态&quot;))
def riseTemperature(self, step):
self.setTemperature(self.__temperature + step)
def reduceTemperature(self, step):
self.setTemperature(self.__temperature - step)
def behavior(self):
self.__state.behavior(self)
class State:
&quot;状态&quot;
def __init__(self, name):
self.__name = name
def getStateName(self):
return self.__name
def behavior(self, water):
pass
class SolidState(State):
&quot;固态&quot;
def __init__(self, name):
super().__init__(name)
def behavior(self, water):
print(&quot;我性格高冷,当前体温&quot;, water.getTemperature(),
&quot;摄氏度,我坚如钢铁,仿如一冷血动物,请用我砸人,嘿嘿……&quot;)
class LiquidState(State):
&quot;液态&quot;
def __init__(self, name):
super().__init__(name)
def behavior(self, water):
print(&quot;我性格温和,当前体温&quot;, water.getTemperature(),
&quot;摄氏度,我可滋润万物,饮用我可让你活力倍增……&quot;)
class GaseousState(State):
&quot;气态&quot;
def __init__(self, name):
super().__init__(name)
def behavior(self, water):
print(&quot;我性格热烈,当前体温&quot;, water.getTemperature(),
&quot;摄氏度,飞向天空是我毕生的梦想,在这你将看不到我的存在,我将达到无我的境界……&quot;)
</code></pre>
<p>测试代码:</p>
@@ -765,9 +495,6 @@ class GaseousState(State):
water.reduceTemperature(80)
water.behavior()
</code></pre>
<p>输出结果:</p>
@@ -793,9 +520,6 @@ class GaseousState(State):
由 液态 变为 固态
我性格高冷,当前体温 -20 摄氏度,我坚如钢铁,仿如一冷血动物,请用我砸人,嘿嘿……
</code></pre>
<h3>从剧情中思考状态模式</h3>
@@ -845,17 +569,11 @@ class GaseousState(State):
# 实际复杂应用场景中,可以将其单独定义成一个类
self.__stateInfo = 0
def addState(self, state):
if (state not in self.__states):
self.__states.append(state)
def changeState(self, state):
if (state is None):
@@ -875,15 +593,9 @@ class GaseousState(State):
self.addState(state)
return True
def getState(self):
return self.__curState
def _setStateInfo(self, stateInfo):
self.__stateInfo = stateInfo
@@ -893,15 +605,9 @@ class GaseousState(State):
if( state.isMatch(stateInfo) ):
self.changeState(state)
def _getStateInfo(self):
return self.__stateInfo
class State:
&quot;状态的基类&quot;
@@ -909,29 +615,17 @@ class State:
def __init__(self, name):
self.__name = name
def getStateName(self):
return self.__name
def isMatch(self, stateInfo):
&quot;状态信息stateInfo是否在当前的状态范围内&quot;
return False
def behavior(self, context):
pass
</code></pre>
<h4>类图</h4>
@@ -947,9 +641,6 @@ class State:
<pre><code class="language-python">class Water(Context):
&quot;水(H2O)&quot;
def __init__(self):
super().__init__()
@@ -961,33 +652,18 @@ class State:
self.addState(GaseousState(&quot;气态&quot;))
self.setTemperature(25)
def getTemperature(self):
return self._getStateInfo()
def setTemperature(self, temperature):
self._setStateInfo(temperature)
def riseTemperature(self, step):
self.setTemperature(self.getTemperature() + step)
def reduceTemperature(self, step):
self.setTemperature(self.getTemperature() - step)
def behavior(self):
state = self.getState()
@@ -995,9 +671,6 @@ class State:
if(isinstance(state, State)):
state.behavior(self)
# 单例的装饰器
def singleton(cls, *args, **kwargs):
@@ -1005,9 +678,6 @@ def singleton(cls, *args, **kwargs):
&quot;构造一个单例的装饰器&quot;
instance = {}
def __singleton(*args, **kwargs):
if cls not in instance:
@@ -1015,33 +685,18 @@ def singleton(cls, *args, **kwargs):
instance[cls] = cls(*args, **kwargs)
return instance[cls]
return __singleton
@singleton
class SolidState(State):
&quot;固态&quot;
def __init__(self, name):
super().__init__(name)
def isMatch(self, stateInfo):
return stateInfo &lt; 0
def behavior(self, context):
if (isinstance(context, Water)):
@@ -1049,29 +704,17 @@ class SolidState(State):
print(&quot;我性格高冷,当前体温&quot;, context.getTemperature(),
&quot;摄氏度,我坚如钢铁,仿如一冷血动物,请用我砸人,嘿嘿……&quot;)
@singleton
class LiquidState(State):
&quot;液态&quot;
def __init__(self, name):
super().__init__(name)
def isMatch(self, stateInfo):
return (stateInfo &gt;= 0 and stateInfo &lt; 100)
def behavior(self, context):
if (isinstance(context, Water)):
@@ -1079,29 +722,17 @@ class LiquidState(State):
print(&quot;我性格温和,当前体温&quot;, context.getTemperature(),
&quot;摄氏度,我可滋润万物,饮用我可让你活力倍增……&quot;)
@singleton
class GaseousState(State):
&quot;气态&quot;
def __init__(self, name):
super().__init__(name)
def isMatch(self, stateInfo):
return stateInfo &gt;= 100
def behavior(self, context):
if (isinstance(context, Water)):
@@ -1109,17 +740,11 @@ class GaseousState(State):
print(&quot;我性格热烈,当前体温&quot;, context.getTemperature(),
&quot;摄氏度,飞向天空是我毕生的梦想,在这你将看不到我的存在,我将达到无我的境界……&quot;)
</code></pre>
<p>这里只要改一下上面测试代码的第一行就可以了:</p>
<pre><code class="language-python">water = Water()
</code></pre>
<p>自己跑一下,会发现输出结果和之前的是一样的。</p>
@@ -1163,9 +788,6 @@ class GaseousState(State):
</div>
</div>
</div>
</div>
@@ -1173,9 +795,6 @@ class GaseousState(State):
</div>
</div>
<a class="off-canvas-overlay" onclick="hide_canvas()"></a>
</div>
@@ -1191,17 +810,11 @@ class GaseousState(State):
<script>
window.dataLayer = window.dataLayer || [];
function gtag() {
dataLayer.push(arguments);
}
gtag('js', new Date());
gtag('config', 'G-NPSEEVD756');
@@ -1227,9 +840,6 @@ class GaseousState(State):
setCookie("lastPath", path)
}
function setCookie(cname, cvalue) {
var d = new Date();
@@ -1241,9 +851,6 @@ class GaseousState(State):
document.cookie = cname + "=" + cvalue + "; " + expires + ";path = /";
}
function getCookie(cname) {
var name = cname + "=";
@@ -1261,12 +868,6 @@ class GaseousState(State):
return "";
}
</script>
</html>