日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python 享元模式_python 设计模式之享元(Flyweight)模式

發(fā)布時間:2023/12/10 python 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python 享元模式_python 设计模式之享元(Flyweight)模式 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

#寫在前面

這個設計模式理解起來很容易。百度百科上說的有點繞口。

#享元模式的定義

運用共享技術來有効地支持大量細粒度對象的復用。

它通過共享已經(jīng)存在的對橡大幅度減少需要創(chuàng)建的對象數(shù)量、避免大量相似類的開銷,從而提高系統(tǒng)資源的利用率。

#優(yōu)點

相同對象只要保存一份,這降低了系統(tǒng)中對象的數(shù)量,從而降低了系統(tǒng)中細粒度對象給內(nèi)存帶來的壓力。

#缺點

1.為了共享對象,需要將不能共享的狀態(tài)外部化,會增加程序的復雜性

2.對享元模式的外部狀態(tài)會增長運行時間

#享元模式中存在的兩種狀態(tài)

1.內(nèi)部狀態(tài),不會隨著環(huán)境的改變而改變,可共享的部分

2.外部狀態(tài),會隨著環(huán)境的改變而改變,是不可共享的部分.

享元模式就是要區(qū)分這兩種狀態(tài),并將外部狀態(tài)外部化。

#應用實例

1.java中的String,如果有則返回,如果沒有就創(chuàng)建一個字符串保存在字符串緩沖池里面。

2.數(shù)據(jù)庫的數(shù)據(jù)池

#應用場景

1.系統(tǒng)中存在大量的相似對象

2.細粒度的對象都具備較接近的外部狀態(tài),而且內(nèi)部狀態(tài)與環(huán)境無關,也就是說對象沒有特定身份

3.需要緩沖池的場景

#享元模式的主要角色

抽象享元角色(Flyweight):是所有的具體享元類的基類,為具體享元規(guī)范需要實現(xiàn)的公共接口,非享元的外部狀態(tài)以參數(shù)的形式通過方法傳入。

具體享元(Concrete Flyweight)角色:實現(xiàn)抽象享元角色中所規(guī)定的接口。

非享元(Unsharable Flyweight)角色:是不可以共享的外部狀態(tài),它以參數(shù)的形式注入具體享元的相關方法中。

享元工廠(Flyweight Factory)角色:負責創(chuàng)建和管理享元角色。當客戶對象請求一個享元對象時,享元工廠檢査系統(tǒng)中是否存在符合要求的享元對象,如果存在則提供給客戶;如果不存在的話,則創(chuàng)建一個新的享元對象。

#舉例說明什么是具體享元角色和非具體享元角色

舉下圍棋的例子

棋子:是抽象享元角色

白子:具體享元角色

黑子:具體享元角色

圍棋工廠:是享元工廠角色

下棋的位置:非具體享元角色

#享元模式的結構圖

#舉個例子1

class Flyweight(object):

def __init__(self, str):

self.str = str

def display(self):

print("show the string: " + self.str)

class FlyweightFactory(object):

def __init__(self):

self.flyweights = {}

def getFlyweight(self, obj):

flyweight = self.flyweights.get(obj)

if flyweight == None:

flyweight = Flyweight(str(obj))

self.flyweights[obj] = flyweight

return flyweight

def showFlyweights(self):

for i in self.flyweights:

self.flyweights[i].display()

print(len(self.flyweights))

if __name__ == "__main__":

flyweightfactory = FlyweightFactory()

fly1 = flyweightfactory.getFlyweight("hello1")

fly2 = flyweightfactory.getFlyweight("hello1")

fly3 = flyweightfactory.getFlyweight("hello2")

fly4 = flyweightfactory.getFlyweight("hello2")

fly5 = flyweightfactory.getFlyweight("hello3")

flyweightfactory.showFlyweights()

out:

show the string: hello2

show the string: hello1

show the string: hello3

3

#舉個例子2

import random

from enum import Enum

TreeType=Enum("TreeType",("apple","cherry","peach"))

class Tree:

pool={} #數(shù)目池

def __new__(cls,tree_type):

obj=cls.pool.get(tree_type,None) #獲取樹苗類型

if not obj: #如果之前沒有創(chuàng)建過

obj=object.__new__(cls) #開辟一塊內(nèi)存空間

cls.pool[tree_type]=obj #在池子里添加這個樹苗類型和他的內(nèi)存空間

obj.tree_type=tree_type #內(nèi)存空間里添加樹苗類型

return obj #返回樹苗類型空間

def render(self,age,x,y):

print("創(chuàng)建了一個新的種類{}的樹苗,他的年齡是{},地點位于{},{}".format(

self.tree_type,age,x,y

))

def main():

rnd=random.Random()

age_min,age_max=1,30 #樹苗年齡在1-30之間隨機

min_point,max_point=0,100 #隨機地點

tree_counter=0

print(rnd)

for _ in range(10): #10個蘋果樹

t1=Tree(TreeType['apple'])

t1.render(rnd.randint(age_min,age_max),

rnd.randint(min_point,max_point),

rnd.randint(min_point, max_point))

tree_counter+=1

for _ in range(3): #3個cherry樹

t2=Tree(TreeType['cherry'])

t2.render(rnd.randint(age_min,age_max),

rnd.randint(min_point,max_point),

rnd.randint(min_point, max_point))

tree_counter+=1

for _ in range(5): #5個peach樹

t3=Tree(TreeType['peach'])

t3.render(rnd.randint(age_min,age_max),

rnd.randint(min_point,max_point),

rnd.randint(min_point, max_point))

tree_counter+=1

print("樹苗創(chuàng)建了{}個".format(tree_counter))

print("樹苗完成創(chuàng)建:{}種類".format(len(Tree.pool)))

t4=Tree(TreeType['cherry'])

t5 = Tree(TreeType['cherry'])

t6=Tree(TreeType['apple'])

print("{}----{}是同一顆樹嗎? {}".format(id(t4),id(t5),id(t4)==id(t5)))

print("{}----{}是同一顆樹嗎? {}".format(id(t5), id(t6), id(t6) == id(t5)))

if __name__ == '__main__':

main()

參考

http://c.biancheng.net/view/1371.html(下圍棋)

https://www.runoob.com/design-pattern/flyweight-pattern.html

https://www.cnblogs.com/hujingnb/p/10171607.html

http://dongweiming.github.io/python-flyweight.html

https://blog.csdn.net/weixin_42557907/article/details/84204040(例子2出處)

https://blog.csdn.net/u013346751/article/details/78426104(例子1出處)

總結

以上是生活随笔為你收集整理的python 享元模式_python 设计模式之享元(Flyweight)模式的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。