成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

PHP中的設計模式 <持續(xù)更新中...>

mgckid / 727人閱讀

摘要:工廠模式工廠模式代碼片段訪問靜態(tài)屬性要加符靜態(tài)方法生成實例對象,作為函數(shù)的參數(shù)工廠就是負責生成對象的類或方法工廠模式,是把創(chuàng)造者類和要生產(chǎn)的類分開,創(chuàng)建者是個工廠類,定義了用于生產(chǎn)產(chǎn)品對象的方法行程特殊的代碼重復,不必要的子類話,為了工


工廠模式
/* 工廠模式代碼片段*/
class Employee{

    private static $type = array("minion", "wellcon", "student");

    public static function recuit($name)
    {
        $num = rand(1, count(Employee::$type)) - 1 ;
        $class = Employee::$type[$num]; // 訪問靜態(tài)屬性要加$符
        return new $class($name);
    }
}
$boss = new Boss();
$boss->addEmployee(Employee::recuit("hard")); // 靜態(tài)方法生成實例對象,作為addEmployee函數(shù)的參數(shù)

工廠就是負責生成對象的類或方法

class Demo {

    public function getInstance($type)
    {
        switch($type){
            case "1":
                return new A();
                break;
            case "2":
                return new B();
                break;
            case "3":
                return new C();
                break;

        }
    }
}

工廠模式,是把創(chuàng)造者類和要生產(chǎn)的類分開,創(chuàng)建者是個工廠類,定義了用于生產(chǎn)產(chǎn)品對象的方法

abstract class commonMessage {

    abstract function getInstance();
}

class A extends commonMessage{

    public function getInstance()
    {
        return new A();
    }
}

class B extends commonMessage{

    public function getInstance()
    {
        return new B();
    }
}

行程特殊的代碼重復,不必要的子類話,為了工廠模式,而為創(chuàng)建類創(chuàng)建子類


抽象工廠模式

對于那些不必須要的子類模式,合并起來,通過一個類中多個方法就可以完成工廠輸出

abstract class messageFactor
{

    abstract function getHeader();

    abstract function getMail();

    abstract function getMobile();

    abstract function getFooter();
}

class smudgeMo extends messageFactor
{

    public function getHeader()
    {
        return "Header";
    }

    public function getMail()
    {
        return new Mail();
    }

    public function getMobile()
    {
        return new Mobile();
    }

    public function getFooter()
    {
        return "Footer";
    }
}

class julylovinMo extends messageFactor
{

// 和上個子類相似
}

雖然減少了子類繼承,但是耦合問題太嚴重,如果增加一個產(chǎn)品類型, 抽象函數(shù)和子類繼承體,都需要增加對應的方法

abstract class factory{

    const APPT = 1;
    const TTD = 1;
    const CONTACT = 1;
    abstract function make($flag_int);
}

class mailModel extends factory{

    public function make($flag_int)
    {
        switch ($flag_int){

            case self::APPT:
                return new apptEncoder();
                break;

            case self::TTD:
                return new ttdEncoder();
                break;

            case self::CONTACT:
                return new contactEncoder();
                break;
        }


    }
}

緊湊型工廠模式,但是耦合度高,不利于維護


單例模式

全局變量將類捆綁于特定環(huán)境中,破壞了封裝
特點:
preference 可以被任何對象調(diào)用,無需將對象作為參數(shù)傳遞
preference 不該保存在全局變量中
系統(tǒng)中不應超過一個preference對象,即只允許實例化一次

class Preference
    {

    static $instance;
    public $name;

    private function __construct()
    {

    }

    public function setName($name)
    {
        $this->name = $name;
    }

    public function getName()
    {
        return $this->name;
    }

    public static function getInstance()
    {
        if (empty(self::$instance)) // 控制了只有一個Preference實例對象
        {
            self::$instance = new Preference();
        }
        return self::$instance;
    }
}

$prf = Preference::getInstance(); // 任何地方可以獲取Preference實例對象
$prf->setName("Julylovin");
echo $prf->getName(); // Julylovin

原型模式

用組合代替繼承,抽象工廠模式有平行層次繼承,會有耦合問題
使用clone關鍵詞復制已經(jīng)存在的產(chǎn)品, 具體產(chǎn)品本身,便成為自身生成的基礎

class sea {
private $navigability = 0 ; //可航行
public function __construct($navigability)
    {
        $this->navigability = $navigability;
    }
}
class earthsea extends sea{}
class plain{}
class earthplain extends plain{}
class forest{}
class earthforest extends forest{}
class factory{

    private $sea;
    private $plain;
    private $forest;

    public function __construct(sea $sea, plain $plain, forest $forest)
    {
        $this->sea = $sea;
        $this->plain = $plain;
        $this->forest = $forest;
    }

    public function getSea()
    {
        return clone $this->sea;// 只是引用對象,是同一個對象,并非兩個對象
    }

    public function getPlain()
    {
        return clone $this->plain;
    }

    public function getForest()
    {
        return clone $this->forest;
    }
}

$earthInstance = new factory(new earthsea(1), new earthplain(), new earthforest()); //海域可航行
$earthInstance->getForest(); // new earthforest() 的實例

組合模式

組合模式有助于集合和組件之間關系建立模型
槍手(Archer)組合成軍隊(Arm),多個槍手可以增加軍隊的戰(zhàn)斗力(bombardStrength)

abstract class unit {

    public function addunit(Unit $unit){
        // 阻止獨立單元再次添加對象
        throw new unitException(get_class($unit)."is a leaf");
    }

    public function removeunit(Unit $unit){
        // 阻止獨立單元刪除添加對象
        throw new unitException(get_class($unit)."is a leaf");
    }
    abstract function bombardStrength();
}

class unitException extends Exception{}

class Archer extends unit {

    public function bombardStrength()
    {
        return 4 ;
    }
}

class Army extends unit{  //組合模式體

    private $units = array();

    public function addunit(Unit $unit)
    {
        if(in_array($unit, $this->units, true))
        {
            return ;
        }
        $this->units[] = $unit;
    }

    public function removeunit(Unit $unit)
    {
        $units = array();
        foreach ($this->units as $item)
        {
            if($item !== $unit)
            {
                $units[] = $item;
            }
        }
        $this->units = $units;
    }

    public function bombardStrength()
    {
        $ret = 0 ;
        foreach ($this->units as $unit)
        {
            $ret += $unit->bombardStrength();
        }
        return $ret;
    }
}

$SubArmy = new Army();
$SubArmy->addunit( new Archer());
$SubArmy->addunit( new Archer());
echo $SubArmy->bombardStrength(); // 8




裝飾模式

組合模式用戶聚合組件,裝飾模式使用類似功能,改變組件具體功能
繼承是共享父類特性的簡單方法,所以當改變某些特性時,各種硬編碼會出現(xiàn)在繼承體
導致功能定義依賴于繼承體,導致代碼增多,導致代碼重復

abstract class tile{

    abstract function get_wealth();
}

class plains extends tile {
    private $wealth = 2;
    public function get_wealth()
    {
        return $this->wealth;
    }
}

class polluted extends plains {
    public function get_wealth()
    {
        return parent::get_wealth()-2;
    }
}

class diamond extends plains{
    public function get_wealth()
    {
        return parent::get_wealth()+10 ;
    }
}
// 上圖組合模式 不容易實現(xiàn)既是鉆石地段又是污染地段的價值,常規(guī)做法,會建立類 diamond_polluted

 裝飾模式是使用組合和委托,而不是單純的繼承
abstract class tile {
    abstract function getwealth();
}

class plains extends tile {
    private $wealth = 2;
    public function getwealth()
    {
        return $this->wealth;
    }
}

abstract class tile_decorate extends tile{
    protected $tile ; // 保護屬性,便于子類和當前類當問
// 構(gòu)造方法,接收實例對象,保存在tile屬性中
    public function __construct(tile $tile)
    {
        $this->tile = $tile;
    }
}

class pollute_decorate extends tile_decorate {
    public function getwealth()
    {
        return $this->tile->getwealth()-4;
    }
}

class diamon_decorate extends tile_decorate {
    public function getwealth()
    {
        return  $this->tile->getwealth()+2;
    }
}

$tile = new plains();
echo $tile->getwealth();
$tile = new diamon_decorate(new plains());
echo  $tile->getwealth();
$tile = new pollute_decorate(new diamon_decorate(new plains())); // 組合成一個整體
echo $tile->getwealth();
// 多個組合及委托,極具靈活性


  多個裝飾器串聯(lián)起來,形成管道,便于創(chuàng)建過濾器,核心組件和裝飾漆組合,對其流程進行過濾緩沖,壓縮
class request_helper{}

abstract class process_request{
    abstract function process(request_helper $req);
}

class main_process extends process_request {
    public function process(request_helper $req)
    {
        echo __CLASS__."is processing 
";
    }
}

abstract class process_decorate extends process_request {

    protected $process_request;
    public function __construct(process_request $pro)
    {
        $this->process_request = $pro;
    }
}

class log_process extends process_decorate {
    public function process(request_helper $req)
    {
        print __CLASS__."is processing log 
";
        $this->process_request->process($req);
    }
}

class authenticate extends process_decorate {
    public function process(request_helper $req)
    {
        print __CLASS__."is processing authentication 
";
        $this->process_request->process($req);
    }
}

class structure_request extends process_decorate {
    public function process(request_helper $req)
    {
        print __CLASS__."is processing structure 
";
        $this->process_request->process($req);
    }
}

$process = new authenticate(new structure_request(new log_process(new main_process())));
$process->process(new request_helper());
// auth->struct->log->main

裝飾模式一定是組合和繼承同時使用
等同于__call 攔截方法,捕捉不存在的方法自動調(diào)用

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/30274.html

相關文章

  • Pyhton自動化測試持續(xù)集成和Jenkins

      小編寫這篇文章的主要目的,給大家進行講解關于Pyhton自動化測試的相關問題,比如如何對其進行持續(xù)集成相關方面的介紹,關于Jenkins這個要怎么去進行操作呢?下面就給大家詳細介紹下?! 〕掷m(xù)集成  官方術(shù)語:  持續(xù)集成(Continuous Integration),也就是我們經(jīng)常說的CI  持續(xù)集成(CI)是一種實踐,可以讓團隊在持續(xù)的基礎上收到反饋并進行改進,不必等到開發(fā)周期后期才尋找...

    89542767 評論0 收藏0
  • pythonGUI多列輸入文本Text的完成

      此篇文章主要是詳細介紹了pythonGUI多列輸入文本Text的控制方式,具有非常好的實用價值,希望能幫助到大家。如有誤或者未考慮到真正的地區(qū),望鼎力相助  Text的屬性wrap  fromtkinterimport*   root=Tk()   root.geometry('200x300')   te=Text(root,height=20,width=15)   #將多...

    89542767 評論0 收藏0
  • pythonmemory_profiler庫制作器和迭代器cpu占用的時間分析

      文章內(nèi)容主要是詳細介紹了pythonmemory_profiler庫制作器和迭代器cpu占用的時間分析,文章內(nèi)容緊扣主題進行詳盡的基本介紹,感興趣的朋友可以了解一下  不進行計算時,生成器和list空間占用  importtime   frommemory_profilerimportprofile   profile(precision=4)   deflist_fun():   start...

    89542767 評論0 收藏0
  • pythonGUI多做輸入文本Text的完成

      文章主要是詳細介紹了pythonGUI多做輸入文本Text的控制方式,具有非常好的實用價值,希望能幫助到大家。如有誤或者未考慮到真正的地區(qū),望鼎力相助  Text的屬性wrap  fromtkinterimport*   root=Tk()   root.geometry('200x300')   te=Text(root,height=20,width=15)   #將多做輸...

    89542767 評論0 收藏0
  • 解讀useEvent顯著降低Hooks負擔的原生Hook

      想要做到就要有更多的學習,你知道為什么React不把他們設為默認方法#useEvent是一個剛剛提案的原生Hook,還處于RFC?,F(xiàn)在我們就一起來討論下  RFC:Request for Comments 提案應用的還十分廣泛  我們先看看在沒有 useEvent 會出現(xiàn)的情況:  functionChat(){   const[text,setText]=useState(''...

    3403771864 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<