99999久久久久久亚洲,欧美人与禽猛交狂配,高清日韩av在线影院,一个人在线高清免费观看,啦啦啦在线视频免费观看www

熱線電話:13121318867

登錄
首頁(yè)精彩閱讀舉例講解Python設(shè)計(jì)模式編程中對(duì)抽象工廠模式的運(yùn)用
舉例講解Python設(shè)計(jì)模式編程中對(duì)抽象工廠模式的運(yùn)用
2018-07-25
收藏

舉例講解Python設(shè)計(jì)模式編程中對(duì)抽象工廠模式的運(yùn)用

這篇文章主要介紹了Python設(shè)計(jì)模式編程中對(duì)抽象工廠模式的運(yùn)用,文中的例子體現(xiàn)了抽象工廠模式程序的一些設(shè)計(jì)優(yōu)化點(diǎn),需要的朋友可以參考下
抽象工廠模式:提供一個(gè)創(chuàng)建一系列相關(guān)或相互依賴對(duì)象的接口,而無(wú)需指定它們具體的類。
優(yōu)點(diǎn):易于交換“產(chǎn)品系列”,只要更改相應(yīng)的工廠即可。
缺點(diǎn):建立產(chǎn)品的時(shí)候很繁瑣,需要增加和修改很多東西。
優(yōu)化1:為了避免客戶端有過(guò)多的邏輯判斷,可以封裝出一個(gè)簡(jiǎn)單工廠類來(lái)生成產(chǎn)品類。
優(yōu)化2:為了減少簡(jiǎn)單工廠類里面的邏輯判斷,可以采用“反射”機(jī)制,直接根據(jù)外部的配置文件讀取出需要使用產(chǎn)品類的信息。    
#encoding=utf-8
#
#by panda
#抽象工廠模式
 
def printInfo(info):
  print unicode(info, 'utf-8').encode('gbk')
    
#抽象產(chǎn)品A:user表
class IUser():
  def Insert(self):
    pass
  def GetUser(self):
    pass
 
#sqlserver實(shí)現(xiàn)的User
class SqlserverUser(IUser):
  def Insert(self):
    printInfo("在SQL Server中給User表增加一條記錄")
  def GetUser(self):
    printInfo("在SQL Server中得到User表的一條記錄")
 
#Access實(shí)現(xiàn)的User
class AccessUser(IUser):
  def Insert(self):
    printInfo("在Access中給User表增加一條記錄")
  def GetUser(self):
    printInfo("在Access中得到User表一條記錄")
 
 
#抽象產(chǎn)品B:部門表
class IDepartment():
  def Insert(self):
    pass
  def GetUser(self):
    pass
 
#sqlserver實(shí)現(xiàn)的Department
class SqlserverDepartment(IUser):
  def Insert(self):
    printInfo("在SQL Server中給Department表增加一條記錄")
  def GetUser(self):
    printInfo("在SQL Server中得到Department表的一條記錄")
 
#Access實(shí)現(xiàn)的Department
class AccessDepartment(IUser):
  def Insert(self):
    printInfo("在Access中給Department表增加一條記錄")
  def GetUser(self):
    printInfo("在Access中得到Department表一條記錄")
 
 
#抽象工廠
class IFactory():
  def CreateUser(self):
    pass
  def CreateDepartment(self):
    pass  
 
#sql server工廠
class SqlServerFactory(IFactory):
  def CreateUser(self):
    return SqlserverUser()
  def CreateDepartment(self):
    return SqlserverDepartment()
 
#access工廠
class AccessFactory(IFactory):
  def CreateUser(self):
    return AccessUser()
  def CreateDepartment(self):
    return AccessDepartment()
    
#優(yōu)化一:采用一個(gè)簡(jiǎn)單工廠類,封裝邏輯判斷操作
class DataAccess():
#  db = "Sqlserver"
  db = "Access"
  @staticmethod
  def CreateUser():
    if (DataAccess.db == "Sqlserver"):
      return SqlserverUser()
    elif(DataAccess.db == "Access"):
      return AccessUser()
  @staticmethod
  def CreateDepartment():
    if (DataAccess.db == "Sqlserver"):
      return SqlserverDepartment()
    elif(DataAccess.db == "Access"):
      return AccessDepartment()
      
#優(yōu)化二:采用反射機(jī)制,避免使用太多判斷
##以下信息可以從配置文件中獲取
DBType = 'Sqlserver' #'Access'
DBTab_User = 'User'
DBTab_Department = 'Department'
 
class DataAccessPro():
#  db = "Sqlserver"
  db = "Access"
  @staticmethod
  def CreateUser():
    funName = DBType + DBTab_User
    return eval(funName)() #eval 將其中的字符串轉(zhuǎn)化為python表達(dá)式
  @staticmethod
  def CreateDepartment():
    funName = DBType + DBTab_Department
    return eval(funName)()
      
def clientUI():
  printInfo("\n--------抽象工廠方法--------")
  factory = SqlServerFactory()
  iu = factory.CreateUser()
  iu.Insert()
  iu.GetUser()
  id = factory.CreateDepartment()
  id.Insert()
  id.GetUser()
    
  printInfo("\n--抽象工廠方法+簡(jiǎn)單工廠方法--")
  iu = DataAccess.CreateUser()
  iu.Insert()
  iu.GetUser()
  id = DataAccess.CreateDepartment()
  id.Insert()
  id.GetUser()
    
  printInfo("\n-抽象工廠方法+簡(jiǎn)單工廠方法+反射-")
  iu = DataAccessPro.CreateUser()
  iu.Insert()
  iu.GetUser()
  id = DataAccessPro.CreateDepartment()
  id.Insert()
  id.GetUser()   
  return
 
 
if __name__ == '__main__':
  clientUI();

類圖:

工廠模式和抽象工廠模式的區(qū)別:工廠模式是在派生類中定義一個(gè)工廠的抽象接口,然后基類負(fù)責(zé)創(chuàng)建具體對(duì)象;抽象工廠模式是維護(hù)一個(gè)產(chǎn)品家族,由基類定義產(chǎn)品被生產(chǎn)的方法,客戶根據(jù)派生類的接口進(jìn)行開(kāi)發(fā)。
實(shí)例:人民群眾喜聞樂(lè)見(jiàn)的披薩店例子這里又可以搬出來(lái)了,這次我們根據(jù)抽象工廠模式的特點(diǎn),用不同原材料制作不同口味的披薩,創(chuàng)建不同原材料的工廠,不同實(shí)體店做出口味不同的披薩。創(chuàng)建一個(gè)產(chǎn)品家族(Dough、Sauce、Cheese和Clam)的抽象類型(PizzaIngredientFactory),這個(gè)類型的子類(NYPizzaIngredientFactory和ChicagoPizzaIngredientFactory)定義了產(chǎn)品被產(chǎn)生的方法。
代碼:
#!/usr/bin/python
# -*- coding:utf-8 -*-
import sys
reload(sys)
sys.setdefaultencoding('utf-8')
 
'''
披薩
'''
class Pizza:
  name = ""
  dough = None
  sauce = None
  cheese = None
  clam = None
 
  def prepare(self):
    pass
 
  def bake(self):
    print "烘烤25分鐘在350。".decode('utf-8')
 
  def cut(self):
    print "切割成對(duì)角線切片。".decode('utf-8')
 
  def box(self):
    print "放在官方的盒子中。".decode('utf-8')
 
  def get_name(self):
    return self.name
 
  def set_name(self, name):
    self.name = name
 
  def to_string(self):
    string = "%s:\n" % self.name
    string += "  面團(tuán): %s\n" % self.dough.to_string() if self.dough else ""
    string += "  醬汁: %s\n" % self.sauce.to_string() if self.sauce else ""
    string += "  奶酪: %s\n" % self.cheese.to_string() if self.cheese else ""
    string += "  文蛤: %s\n" % self.clam.to_string() if self.clam else ""
    return string
 
'''
什么類別的披薩
'''
class CheesePizza(Pizza):
  def __init__(self, ingredient_factory):
    self.ingredient_factory = ingredient_factory
 
  def prepare(self):
    print "準(zhǔn)備: %s" % self.name
    self.dough = self.ingredient_factory.create_dough()
    self.sauce = self.ingredient_factory.create_sauce()
    self.cheese = self.ingredient_factory.create_cheese()
 
 
class ClamPizza(Pizza):
  def __init__(self, ingredient_factory):
    self.ingredient_factory = ingredient_factory
 
  def prepare(self):
    print "準(zhǔn)備: %s" % self.name
    self.dough = self.ingredient_factory.create_dough()
    self.sauce = self.ingredient_factory.create_sauce()
    self.clam = self.ingredient_factory.create_clam()
 
'''
披薩店
'''
class PizzaStore:
  def order_pizza(self, pizza_type):
    self.pizza = self.create_pizza(pizza_type)
    self.pizza.prepare()
    self.pizza.bake()
    self.pizza.cut()
    self.pizza.box()
    return self.pizza
 
  def create_pizza(self, pizza_type):
    pass
 
'''
紐約披薩實(shí)體店1
'''
class NYPizzaStore(PizzaStore):
  def create_pizza(self, pizza_type):
    ingredient_factory = NYPizzaIngredientFactory()
 
    if pizza_type == "cheese":
      pizza = CheesePizza(ingredient_factory)
      pizza.set_name("紐約風(fēng)格芝士披薩".decode('utf-8'))
    elif pizza_type == "clam":
      pizza = ClamPizza(ingredient_factory)
      pizza.set_name("紐約風(fēng)格文蛤披薩".decode('utf-8'))
    else:
      pizza = None
 
    return pizza
 
'''
芝加哥披薩實(shí)體店2
'''
class ChicagoPizzaStore(PizzaStore):
   def create_pizza(self, pizza_type):
    ingredient_factory = ChicagoPizzaIngredientFactory()
 
    if pizza_type == "cheese":
      pizza = CheesePizza(ingredient_factory)
      pizza.set_name("芝加哥風(fēng)格芝士披薩".decode('utf-8'))
    elif pizza_type == "clam":
      pizza = ClamPizza(ingredient_factory)
      pizza.set_name("芝加哥風(fēng)格文蛤披薩".decode('utf-8'))
    else:
      pizza = None
 
    return pizza
 
'''
生產(chǎn)披薩的工廠
'''
class PizzaIngredientFactory:
  def create_dough(self):
    pass
 
  def create_sauce(self):
    pass
 
  def create_cheese(self):
    pass
 
  def create_clam(self):
    pass
 
'''
生產(chǎn)披薩的實(shí)體工廠1
'''
class NYPizzaIngredientFactory(PizzaIngredientFactory):
  def create_dough(self):
    return ThinDough()
 
  def create_sauce(self):
    return MarinaraSauce()
 
  def create_cheese(self):
    return FreshCheese()
 
  def create_clam(self):
    return FreshClam()
 
'''
生產(chǎn)披薩的實(shí)體工廠2
'''
class ChicagoPizzaIngredientFactory(PizzaIngredientFactory):
  def create_dough(self):
    return ThickDough()
 
  def create_sauce(self):
    return MushroomSauce()
 
  def create_cheese(self):
    return BlueCheese()
 
  def create_clam(self):
    return FrozenClam()
 
 
class Dough:
  def to_string(self):
    pass
 
class ThinDough(Dough):
  def to_string(self):
    return "薄的面團(tuán)"
 
class ThickDough(Dough):
  def to_string(self):
    return "厚的生面團(tuán)"
 
class Sauce:
  def to_string(self):
    pass
 
class MarinaraSauce(Sauce):
  def to_string(self):
    return "番茄醬"
 
class MushroomSauce(Sauce):
  def to_string(self):
    return "蘑菇醬"
 
class Cheese:
  def to_string(self):
    pass
 
class FreshCheese(Cheese):
  def to_string(self):
    return "新鮮的奶酪"
 
class BlueCheese(Cheese):
  def to_string(self):
    return "藍(lán)紋奶酪"
 
class Clam:
  def to_string(self):
    pass
 
class FreshClam(Clam):
  def to_string(self):
    return "新鮮的文蛤"
 
class FrozenClam(Clam):
  def to_string(self):
    return "冷凍的文蛤"
 
if __name__ == "__main__":
  # 創(chuàng)建了兩個(gè)披薩實(shí)體店
  ny_store = NYPizzaStore()
  chicago_store = ChicagoPizzaStore()
 
  # 在第一個(gè)披薩對(duì)象中訂購(gòu)了一個(gè)cheese風(fēng)味的披薩
  pizza = ny_store.order_pizza("cheese")
  print pizza.to_string()
  print "邁克訂購(gòu)了一個(gè) %s" % pizza.get_name()
  print
 
  pizza = chicago_store.order_pizza("clam")
  print pizza.to_string()
  print "約翰訂購(gòu)了一個(gè)%s" % pizza.get_name()

結(jié)果:    
準(zhǔn)備: 紐約風(fēng)格芝士披薩
烘烤25分鐘在350。
切割成對(duì)角線切片。
放在官方的盒子中。
紐約風(fēng)格芝士披薩:
  面團(tuán): 薄的面團(tuán)
  醬汁: 番茄醬
  奶酪: 新鮮的奶酪
 
邁克訂購(gòu)了一個(gè) 紐約風(fēng)格芝士披薩
 
準(zhǔn)備: 芝加哥風(fēng)格文蛤披薩
烘烤25分鐘在350。
切割成對(duì)角線切片。
放在官方的盒子中。
芝加哥風(fēng)格文蛤披薩:
  面團(tuán): 厚的生面團(tuán)
  醬汁: 蘑菇醬
  文蛤: 冷凍的文蛤
 
約翰訂購(gòu)了一個(gè)芝加哥風(fēng)格文蛤披薩

數(shù)據(jù)分析咨詢請(qǐng)掃描二維碼

若不方便掃碼,搜微信號(hào):CDAshujufenxi

數(shù)據(jù)分析師資訊
更多

OK
客服在線
立即咨詢
客服在線
立即咨詢
') } function initGt() { var handler = function (captchaObj) { captchaObj.appendTo('#captcha'); captchaObj.onReady(function () { $("#wait").hide(); }).onSuccess(function(){ $('.getcheckcode').removeClass('dis'); $('.getcheckcode').trigger('click'); }); window.captchaObj = captchaObj; }; $('#captcha').show(); $.ajax({ url: "/login/gtstart?t=" + (new Date()).getTime(), // 加隨機(jī)數(shù)防止緩存 type: "get", dataType: "json", success: function (data) { $('#text').hide(); $('#wait').show(); // 調(diào)用 initGeetest 進(jìn)行初始化 // 參數(shù)1:配置參數(shù) // 參數(shù)2:回調(diào),回調(diào)的第一個(gè)參數(shù)驗(yàn)證碼對(duì)象,之后可以使用它調(diào)用相應(yīng)的接口 initGeetest({ // 以下 4 個(gè)配置參數(shù)為必須,不能缺少 gt: data.gt, challenge: data.challenge, offline: !data.success, // 表示用戶后臺(tái)檢測(cè)極驗(yàn)服務(wù)器是否宕機(jī) new_captcha: data.new_captcha, // 用于宕機(jī)時(shí)表示是新驗(yàn)證碼的宕機(jī) product: "float", // 產(chǎn)品形式,包括:float,popup width: "280px", https: true // 更多配置參數(shù)說(shuō)明請(qǐng)參見(jiàn):http://docs.geetest.com/install/client/web-front/ }, handler); } }); } function codeCutdown() { if(_wait == 0){ //倒計(jì)時(shí)完成 $(".getcheckcode").removeClass('dis').html("重新獲取"); }else{ $(".getcheckcode").addClass('dis').html("重新獲取("+_wait+"s)"); _wait--; setTimeout(function () { codeCutdown(); },1000); } } function inputValidate(ele,telInput) { var oInput = ele; var inputVal = oInput.val(); var oType = ele.attr('data-type'); var oEtag = $('#etag').val(); var oErr = oInput.closest('.form_box').next('.err_txt'); var empTxt = '請(qǐng)輸入'+oInput.attr('placeholder')+'!'; var errTxt = '請(qǐng)輸入正確的'+oInput.attr('placeholder')+'!'; var pattern; if(inputVal==""){ if(!telInput){ errFun(oErr,empTxt); } return false; }else { switch (oType){ case 'login_mobile': pattern = /^1[3456789]\d{9}$/; if(inputVal.length==11) { $.ajax({ url: '/login/checkmobile', type: "post", dataType: "json", data: { mobile: inputVal, etag: oEtag, page_ur: window.location.href, page_referer: document.referrer }, success: function (data) { } }); } break; case 'login_yzm': pattern = /^\d{6}$/; break; } if(oType=='login_mobile'){ } if(!!validateFun(pattern,inputVal)){ errFun(oErr,'') if(telInput){ $('.getcheckcode').removeClass('dis'); } }else { if(!telInput) { errFun(oErr, errTxt); }else { $('.getcheckcode').addClass('dis'); } return false; } } return true; } function errFun(obj,msg) { obj.html(msg); if(msg==''){ $('.login_submit').removeClass('dis'); }else { $('.login_submit').addClass('dis'); } } function validateFun(pat,val) { return pat.test(val); }