mirror of
https://github.com/zhwei820/learn.lianglianglee.com.git
synced 2025-11-16 06:03:45 +08:00
u
This commit is contained in:
@@ -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 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 class="current-tab" 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">
|
||||
@@ -567,9 +363,6 @@ function hide_canvas() {
|
||||
<pre><code class="language-python">class PowerBank:
|
||||
|
||||
"移动电源"
|
||||
|
||||
|
||||
|
||||
def __init__(self, serialNum, electricQuantity):
|
||||
|
||||
self.__serialNum = serialNum
|
||||
@@ -577,39 +370,21 @@ function hide_canvas() {
|
||||
self.__electricQuantity = electricQuantity
|
||||
|
||||
self.__user = ''
|
||||
|
||||
|
||||
|
||||
def getSerialNum(self):
|
||||
|
||||
return self.__serialNum
|
||||
|
||||
|
||||
|
||||
def getElectricQuantity(self):
|
||||
|
||||
return self.__electricQuantity
|
||||
|
||||
|
||||
|
||||
def setUser(self, user):
|
||||
|
||||
self.__user = user
|
||||
|
||||
|
||||
|
||||
def getUser(self):
|
||||
|
||||
return self.__user
|
||||
|
||||
|
||||
|
||||
def showInfo(self):
|
||||
|
||||
print("序列号:" + str(self.__serialNum) + " 电量:" + str(self.__electricQuantity) + "% 使用者:" + self.__user)
|
||||
|
||||
|
||||
|
||||
class ObjectPack:
|
||||
|
||||
"对象的包装类,封装指定的对象(如充电宝)是否被使用中"
|
||||
@@ -619,33 +394,18 @@ class ObjectPack:
|
||||
self.__obj = obj
|
||||
|
||||
self.__inUsing = inUsing
|
||||
|
||||
|
||||
|
||||
def inUsing(self):
|
||||
|
||||
return self.__inUsing
|
||||
|
||||
|
||||
|
||||
def setUsing(self, isUsing):
|
||||
|
||||
self.__inUsing = isUsing
|
||||
|
||||
|
||||
|
||||
def getObj(self):
|
||||
|
||||
return self.__obj
|
||||
|
||||
|
||||
|
||||
class PowerBankBox:
|
||||
|
||||
"存放移动电源的智能箱盒"
|
||||
|
||||
|
||||
|
||||
def __init__(self):
|
||||
|
||||
self.__pools = {}
|
||||
@@ -653,9 +413,6 @@ class PowerBankBox:
|
||||
self.__pools['0001'] = ObjectPack(PowerBank('0001', 100))
|
||||
|
||||
self.__pools['0002'] = ObjectPack(PowerBank('0002', 100))
|
||||
|
||||
|
||||
|
||||
def borrow(self, serialNum):
|
||||
|
||||
"使用移动电源"
|
||||
@@ -679,9 +436,6 @@ class PowerBankBox:
|
||||
print(str(serialNum) + "电源已被借用!")
|
||||
|
||||
return result
|
||||
|
||||
|
||||
|
||||
def giveBack(self, serialNum):
|
||||
|
||||
"归还移动电源"
|
||||
@@ -693,9 +447,6 @@ class PowerBankBox:
|
||||
item.setUsing(False)
|
||||
|
||||
print(str(serialNum) + "电源已归还!")
|
||||
|
||||
|
||||
|
||||
</code></pre>
|
||||
|
||||
<p>测试代码:</p>
|
||||
@@ -731,9 +482,6 @@ class PowerBankBox:
|
||||
powerBank3.setUser('Aimee')
|
||||
|
||||
powerBank3.showInfo()
|
||||
|
||||
|
||||
|
||||
</code></pre>
|
||||
|
||||
<p>输出结果:</p>
|
||||
@@ -747,9 +495,6 @@ class PowerBankBox:
|
||||
0001电源已归还!
|
||||
|
||||
序列号:0001 电量:100% 使用者:Aimee
|
||||
|
||||
|
||||
|
||||
</code></pre>
|
||||
|
||||
<h3>从剧情中思考对象池机制</h3>
|
||||
@@ -803,53 +548,29 @@ import logging
|
||||
import time
|
||||
|
||||
# 引入时间模块
|
||||
|
||||
|
||||
|
||||
class PooledObject:
|
||||
|
||||
"池对象,也称池化对象"
|
||||
|
||||
|
||||
|
||||
def __init__(self, obj):
|
||||
|
||||
self.__obj = obj
|
||||
|
||||
self.__busy = False
|
||||
|
||||
|
||||
|
||||
def getObject(self):
|
||||
|
||||
return self.__obj
|
||||
|
||||
|
||||
|
||||
def setObject(self, obj):
|
||||
|
||||
self.__obj = obj
|
||||
|
||||
|
||||
|
||||
def isBusy(self):
|
||||
|
||||
return self.__busy
|
||||
|
||||
|
||||
|
||||
def setBusy(self, busy):
|
||||
|
||||
self.__busy = busy
|
||||
|
||||
|
||||
|
||||
class ObjectPool(metaclass=ABCMeta):
|
||||
|
||||
"对象池"
|
||||
|
||||
|
||||
|
||||
"对象池初始化大小"
|
||||
|
||||
InitialNumOfObjects = 10
|
||||
@@ -857,9 +578,6 @@ class ObjectPool(metaclass=ABCMeta):
|
||||
"对象池最大的大小"
|
||||
|
||||
MaxNumOfObjects = 50
|
||||
|
||||
|
||||
|
||||
def __init__(self):
|
||||
|
||||
self.__pools = []
|
||||
@@ -869,9 +587,6 @@ class ObjectPool(metaclass=ABCMeta):
|
||||
obj = self.createPooledObject()
|
||||
|
||||
self.__pools.append(obj)
|
||||
|
||||
|
||||
|
||||
@abstractmethod
|
||||
|
||||
def createPooledObject(self):
|
||||
@@ -879,9 +594,6 @@ class ObjectPool(metaclass=ABCMeta):
|
||||
"子类提供创建对象的方法"
|
||||
|
||||
pass
|
||||
|
||||
|
||||
|
||||
def borrowObject(self):
|
||||
|
||||
# 如果找到空闲对象,直接返回
|
||||
@@ -893,9 +605,6 @@ class ObjectPool(metaclass=ABCMeta):
|
||||
logging.info("%s对象已被借用, time:%d", id(obj), time.time())
|
||||
|
||||
return obj
|
||||
|
||||
|
||||
|
||||
# 如果对象池未满,则添加新的对象
|
||||
|
||||
if(len(self.__pools) < ObjectPool.MaxNumOfObjects):
|
||||
@@ -909,15 +618,9 @@ class ObjectPool(metaclass=ABCMeta):
|
||||
logging.info("%s对象已被借用, time:%d", id(pooledObj.getObject()), time.time())
|
||||
|
||||
return pooledObj.getObject()
|
||||
|
||||
|
||||
|
||||
# 对象池已满且没有空闲对象,则返回None
|
||||
|
||||
return None
|
||||
|
||||
|
||||
|
||||
def returnObject(self, obj):
|
||||
|
||||
for pooledObj in self.__pools:
|
||||
@@ -929,9 +632,6 @@ class ObjectPool(metaclass=ABCMeta):
|
||||
logging.info("%s对象已归还, time:%d", id(pooledObj.getObject()), time.time())
|
||||
|
||||
break
|
||||
|
||||
|
||||
|
||||
def addObject(self):
|
||||
|
||||
obj = None
|
||||
@@ -945,15 +645,9 @@ class ObjectPool(metaclass=ABCMeta):
|
||||
logging.info("添加新对象%s, time:%d", id(obj), time.time())
|
||||
|
||||
return obj
|
||||
|
||||
|
||||
|
||||
def clear(self):
|
||||
|
||||
self.__pools.clear()
|
||||
|
||||
|
||||
|
||||
def _findFreeObject(self):
|
||||
|
||||
"查找空闲的对象"
|
||||
@@ -971,9 +665,6 @@ class ObjectPool(metaclass=ABCMeta):
|
||||
break
|
||||
|
||||
return obj
|
||||
|
||||
|
||||
|
||||
</code></pre>
|
||||
|
||||
<h4>类图</h4>
|
||||
@@ -991,9 +682,6 @@ class ObjectPool(metaclass=ABCMeta):
|
||||
<pre><code class="language-python">class PowerBank:
|
||||
|
||||
"移动电源"
|
||||
|
||||
|
||||
|
||||
def __init__(self, serialNum, electricQuantity):
|
||||
|
||||
self.__serialNum = serialNum
|
||||
@@ -1001,47 +689,23 @@ class ObjectPool(metaclass=ABCMeta):
|
||||
self.__electricQuantity = electricQuantity
|
||||
|
||||
self.__user = ""
|
||||
|
||||
|
||||
|
||||
def getSerialNum(self):
|
||||
|
||||
return self.__serialNum
|
||||
|
||||
|
||||
|
||||
def getElectricQuantity(self):
|
||||
|
||||
return self.__electricQuantity
|
||||
|
||||
|
||||
|
||||
def setUser(self, user):
|
||||
|
||||
self.__user = user
|
||||
|
||||
|
||||
|
||||
def getUser(self):
|
||||
|
||||
return self.__user
|
||||
|
||||
|
||||
|
||||
def showInfo(self):
|
||||
|
||||
print("序列号:%03d 电量:%d%% 使用者:%s" % (self.__serialNum, self.__electricQuantity, self.__user))
|
||||
|
||||
|
||||
|
||||
class PowerBankPool(ObjectPool):
|
||||
|
||||
|
||||
|
||||
__serialNum = 0
|
||||
|
||||
|
||||
|
||||
@classmethod
|
||||
|
||||
def getSerialNum(cls):
|
||||
@@ -1049,17 +713,11 @@ class PowerBankPool(ObjectPool):
|
||||
cls.__serialNum += 1
|
||||
|
||||
return cls.__serialNum
|
||||
|
||||
|
||||
|
||||
def createPooledObject(self):
|
||||
|
||||
powerBank = PowerBank(PowerBankPool.getSerialNum(), 100)
|
||||
|
||||
return PooledObject(powerBank)
|
||||
|
||||
|
||||
|
||||
</code></pre>
|
||||
|
||||
<p>测试代码得稍微改一下:</p>
|
||||
@@ -1095,17 +753,11 @@ class PowerBankPool(ObjectPool):
|
||||
powerBank3.setUser("Aimee")
|
||||
|
||||
powerBank3.showInfo()
|
||||
|
||||
|
||||
|
||||
powerBankPool.returnObject(powerBank2)
|
||||
|
||||
powerBankPool.returnObject(powerBank3)
|
||||
|
||||
powerBankPool.clear()
|
||||
|
||||
|
||||
|
||||
</code></pre>
|
||||
|
||||
<p>输出结果:</p>
|
||||
@@ -1115,9 +767,6 @@ class PowerBankPool(ObjectPool):
|
||||
序列号:002 电量:100% 使用者:Sam
|
||||
|
||||
序列号:001 电量:100% 使用者:Aimee
|
||||
|
||||
|
||||
|
||||
</code></pre>
|
||||
|
||||
<h4>设计要点</h4>
|
||||
@@ -1187,9 +836,6 @@ class PowerBankPool(ObjectPool):
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
</div>
|
||||
|
||||
</div>
|
||||
@@ -1197,9 +843,6 @@ class PowerBankPool(ObjectPool):
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
<a class="off-canvas-overlay" onclick="hide_canvas()"></a>
|
||||
|
||||
</div>
|
||||
@@ -1215,17 +858,11 @@ class PowerBankPool(ObjectPool):
|
||||
<script>
|
||||
|
||||
window.dataLayer = window.dataLayer || [];
|
||||
|
||||
|
||||
|
||||
function gtag() {
|
||||
|
||||
dataLayer.push(arguments);
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
gtag('js', new Date());
|
||||
|
||||
gtag('config', 'G-NPSEEVD756');
|
||||
@@ -1251,9 +888,6 @@ class PowerBankPool(ObjectPool):
|
||||
setCookie("lastPath", path)
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
function setCookie(cname, cvalue) {
|
||||
|
||||
var d = new Date();
|
||||
@@ -1265,9 +899,6 @@ class PowerBankPool(ObjectPool):
|
||||
document.cookie = cname + "=" + cvalue + "; " + expires + ";path = /";
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
function getCookie(cname) {
|
||||
|
||||
var name = cname + "=";
|
||||
@@ -1285,12 +916,6 @@ class PowerBankPool(ObjectPool):
|
||||
return "";
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
</script>
|
||||
|
||||
|
||||
|
||||
</html>
|
||||
|
||||
|
||||
Reference in New Issue
Block a user