單例模式
專注于為中小企業(yè)提供成都網(wǎng)站建設(shè)、做網(wǎng)站服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)通山免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了數(shù)千家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。
$_instance必須聲明為靜態(tài)的私有變量
構(gòu)造函數(shù)和析構(gòu)函數(shù)必須聲明為私有,防止外部程序new 類從而失去單例模式的意義
getInstance()方法必須設(shè)置為公有的,必須調(diào)用此方法 以返回實例的一個引用
::操作符只能訪問靜態(tài)變量和靜態(tài)函數(shù)
new對象都會消耗內(nèi)存
使用場景:最常用的地方是數(shù)據(jù)庫連接。
使用單例模式生成一個對象后, 該對象可以被其它眾多對象所使用。
私有的__clone()方法防止克隆對象
單例模式,使某個類的對象僅允許創(chuàng)建一個。構(gòu)造函數(shù)private修飾,?
申明一個static getInstance方法,在該方法里創(chuàng)建該對象的實例。如果該實例已經(jīng)存在,則不創(chuàng)建。比如只需要創(chuàng)建一個數(shù)據(jù)庫連接。
工廠模式
工廠模式,工廠方法或者類生成對象,而不是在代碼中直接new。?
使用工廠模式,可以避免當(dāng)改變某個類的名字或者方法之后,在調(diào)用這個類的所有的代碼中都修改它的名字或者參數(shù)。
* 如果某個類在很多的文件中都new ClassName(),那么萬一這個類的名字
* 發(fā)生變更或者參數(shù)發(fā)生變化,如果不使用工廠模式,就需要修改每一個PHP
* 代碼,使用了工廠模式之后,只需要修改工廠類或者方法就可以了。
注冊模式
注冊模式,解決全局共享和交換對象。已經(jīng)創(chuàng)建好的對象,掛在到某個全局可以使用的數(shù)組上,在需要使用的時候,直接從該數(shù)組上獲取即可。將對象注冊到全局的樹上。任何地方直接去訪問。
策略模式
策略模式,將一組特定的行為和算法封裝成類,以適應(yīng)某些特定的上下文環(huán)境。?
eg:假如有一個電商網(wǎng)站系統(tǒng),針對男性女性用戶要各自跳轉(zhuǎn)到不同的商品類目,并且所有的廣告位展示不同的廣告。在傳統(tǒng)的代碼中,都是在系統(tǒng)中加入各種if else的判斷,硬編碼的方式。如果有一天增加了一種用戶,就需要改寫代碼。使用策略模式,如果新增加一種用戶類型,只需要增加一種策略就可以。其他所有的地方只需要使用不同的策略就可以。?
首先聲明策略的接口文件,約定了策略的包含的行為。然后,定義各個具體的策略實現(xiàn)類。
執(zhí)行結(jié)果圖:?
總結(jié):?
通過以上方式,可以發(fā)現(xiàn),在不同用戶登錄時顯示不同的內(nèi)容,但是解決了在顯示時的硬編碼的問題。如果要增加一種策略,只需要增加一種策略實現(xiàn)類,然后在入口文件中執(zhí)行判斷,傳入這個類即可。實現(xiàn)了解耦。?
實現(xiàn)依賴倒置和控制反轉(zhuǎn)?(有待理解)?
通過接口的方式,使得類和類之間不直接依賴。在使用該類的時候,才動態(tài)的傳入該接口的一個實現(xiàn)類。如果要替換某個類,只需要提供一個實現(xiàn)了該接口的實現(xiàn)類,通過修改一行代碼即可完成替換。
觀察者模式
1:觀察者模式(Observer),當(dāng)一個對象狀態(tài)發(fā)生變化時,依賴它的對象全部會收到通知,并自動更新。?
2:場景:一個事件發(fā)生后,要執(zhí)行一連串更新操作。傳統(tǒng)的編程方式,就是在事件的代碼之后直接加入處理的邏輯。當(dāng)更新的邏輯增多之后,代碼會變得難以維護(hù)。這種方式是耦合的,侵入式的,增加新的邏輯需要修改事件的主體代碼。?
3:觀察者模式實現(xiàn)了低耦合,非侵入式的通知與更新機(jī)制。?
定義一個事件觸發(fā)抽象類。
當(dāng)某個事件發(fā)生后,需要執(zhí)行的邏輯增多時,可以以松耦合的方式去增刪邏輯。也就是代碼中的紅色部分,只需要定義一個實現(xiàn)了觀察者接口的類,實現(xiàn)復(fù)雜的邏輯,然后在紅色的部分加上一行代碼即可。這樣實現(xiàn)了低耦合。
裝飾器模式
1:裝飾器模式,可以動態(tài)的添加修改類的功能?
2:一個類提供了一項功能,如果要在修改并添加額外的功能,傳統(tǒng)的編程模式,需要寫一個子類繼承它,并重寫實現(xiàn)類的方法?
3:使用裝飾器模式,僅需要在運行時添加一個裝飾器對象即可實現(xiàn),可以實現(xiàn)最大額靈活性。
工廠類:你可以理解成寫流程控制
模型類:你可以理解成數(shù)據(jù)的對象,根據(jù)數(shù)據(jù)表生成的對應(yīng)的對象,字段是對象屬性。
MiniFramework 是一款遵循 Apache2 開源協(xié)議發(fā)布的,支持 MVC 和 RESTful 的超輕量級 PHP 開發(fā)框架。MiniFramework 能夠幫助開發(fā)者用最小的學(xué)習(xí)成本快速構(gòu)建 Web 應(yīng)用,在滿足開發(fā)者最基礎(chǔ)的分層開發(fā)、數(shù)據(jù)庫和緩存訪問等少量功能基礎(chǔ)上,做到盡可能精簡,以幫助您的應(yīng)用基于框架高效運行。
MiniFramework于2019年6月11日發(fā)布2.0.0版本,變化有:
* 重構(gòu)框架核心架構(gòu),按功能模塊劃分目錄和命名空間。
* 新增命名空間Mini\Base,用于框架基礎(chǔ)類庫。
* 新增命名空間Mini\Cache,用于緩存類庫。
* 新增命名空間Mini\Captcha,用于驗證碼等人機(jī)識別校驗類庫。
* 新增命名空間Mini\Db,用于數(shù)據(jù)庫操作類庫。
* 新增命名空間Mini\Helpers,用于全靜態(tài)助手類庫。
* 新增常量CSRF_TOKEN_ON,默認(rèn)值為TRUE,用于控制防御CSRF跨站請求偽造攻擊功能的開啟和關(guān)閉。
* 新增方法Mini\Base\Request::checkCsrfToken(),用于校驗客戶端傳入CSRF-Token。
* 新增方法Mini\Base\Request::createCsrfToken(),用于生成一個新的CSRF-Token。
* 新增方法Mini\Base\Request::getCsrfParamName(),用于獲取CSRF-Token存儲鍵名。
* 新增方法Mini\Base\Request::loadCsrfToken(),用于讀取CSRF-Token。
* 新增方法Mini\Helpers\Safe::getCsrfToken(),用于隨時獲取當(dāng)前存儲于Server端的CSRF-Token。
* 改進(jìn)Mini\Db類庫,支持原有工廠模式調(diào)用和直接調(diào)用MySQL類Mini\Db\Mysql兩種模式并存。
* 改進(jìn)Mini\Cache類庫,支持原有工廠模式和直接調(diào)用File、Memcache、Memcached和Redis類兩種模式并存。
* 創(chuàng)建框架核心代碼倉庫 用于正式版本發(fā)布。
* 完善用于演示的應(yīng)用示例App。
* 完善Composer配置,更好的支持在項目中通過Composer引入框架進(jìn)行編碼。
* 完善代碼注釋。
MiniFramework 2.0.0 版本下載地址
zip格式:
tar.gz格式:
MiniFramework 快速入門文檔
地址:
近期版本更新主要變化回顧:
1.5.2
* 新增全局函數(shù)htmlEncode(),用于轉(zhuǎn)換特殊字符為HTML實體字符,便于防范XSS攻擊。
* 更新composer.json中定義的包名,從命名上與Github的倉庫名稱保持一致。