[TOC]
* * * * *
## 1 數據緩存文件源代碼(/thinkphp/library/think/Cache.php)
~~~
protected static $instance = [];
public static $readTimes = 0;
public static $writeTimes = 0;
protected static $handler = null;
~~~
~~~
public static function connect(array $options = [])
{
$md5 = md5(serialize($options));
if (!isset(self::$instance[$md5])) {
$type = !empty($options['type']) ? $options['type'] : 'File';
$class = (!empty($options['namespace']) ? $options['namespace'] : '\\think\\cache\\driver\\') . ucwords($type);
unset($options['type']);
self::$instance[$md5] = new $class($options);
APP_DEBUG && Log::record('[ CACHE ] INIT ' . $type . ':' . var_export($options, true), 'info');
}
self::$handler = self::$instance[$md5];
return self::$handler;
}
~~~
~~~
public static function __callStatic($method, $params)
{
if (is_null(self::$handler)) {
self::connect(Config::get('cache'));
}
return call_user_func_array([self::$handler, $method], $params);
}
~~~
## 2 文件分析
> $instance:緩存對象實例數組
> $readTimes,$writeTimes:???
> $heandler:當前緩存處理句柄
1 `public static function connect(array $options=[])`
> $options 緩存配置參數
這里的參數與緩存驅動目錄的緩存驅動文件參數一致,
以/thinkphp/library/think/cache/File.php為例
~~~
protected $options = [
'expire' => 0,
'cache_subdir' => false,
'path_level' => 1,
'prefix' => '',
'length' => 0,
'path' => LOG_PATH,
'data_compress' => false,
];
~~~
`$md5 = md5(serialize($options));`
將配置參數組織為作為緩存對象索引
`if (!isset(self::$instance[$md5])) {}`
檢查$instance中是否存在對應索引的緩存對象
`$type = !empty($options['type']) ? $options['type'] : 'File';`
緩存類型,默認為File
`$class = (!empty($options['namespace']) ? $options['namespace'] : '\\think\\cache\\driver\\') . ucwords($type);`
根據緩存類型,獲取緩存驅動目錄下的文件默認為File.php
`unset($options['type']);`
刪除緩存驅動類型配置,防止創建其他類型出錯
`self::$instance[$md5] = new $class($options);`
創建對應緩存驅動對象 默認為File()
`APP_DEBUG && Log::record('[ CACHE ] INIT ' . $type . ':' . var_export($options, true), 'info');`
日志記錄
~~~
self::$handler = self::$instance[$md5];
return self::$handler;
~~~
保存創建的緩存對象到處理句柄,并返回
* * * * *
2 `public static function __callStatic($method, $params){}`
> $method:調用的緩存句柄的方法
> $params:調用方法傳遞的參數
使用魔術方法調用緩存驅動方法
關于魔術方式的原理見php的魔術方法
~~~
if (is_null(self::$handler)) {
self::connect(Config::get('cache'));
}
~~~
如果沒有self::$handler,則調用self::connect()創建緩存處理句柄
`return call_user_func_array([self::$handler, $method], $params);`
使用call_user_func_array 以$params調用$handler的$method,
關于call_user_func_array的原理見php的反射
## 3 使用方法
1 緩存配置
在全局默認配置文析convention.php件的分析中,有關緩存的配置參數如下
~~~
'cache' => [
'type' => 'File',
'path' => CACHE_PATH,
'prefix' => '',
'expire' => 0,
],
~~~
> type 緩存類型默認為File
> path 緩存目錄默認為CACHE_PATH,在base.php中定義,
> prefix 緩存前綴
> expire 緩存時間
* * * * *
2 框架使用范例分析
打開文件thinkphp/library/think/Template.php,查找
` Cache::set($this->config['cache_id'], $content, $this->config['cache_time']);`
Cache::set()調用$handler的set方法,
也就是thinkphp/library/think/cache/File.php文件中的set()方法。
其分析見驅動擴展的D:(\cache)緩存驅動
* * * * *
3 緩存方法
在輔助函數helper.php中的S()方法可以用來快速緩存,
使用方法與tp3.2類似,參考[官方手冊](http://www.hmoore.net/manual/thinkphp/1835)
## 4 總結
tp5支持豐富多樣的緩存實現,具體的緩存實現見 驅動擴展的[D:(\cache)緩存驅動](http://www.hmoore.net/zmwtp/tp5/120856)
tp5在輔助helper.php文件中使用S()封裝了緩存的快捷接口,分析見 [另:(helper.php)輔助函數](http://www.hmoore.net/zmwtp/tp5/120824)
緩存大量使用在框架的模板解析(Template.php)中。使用方法見[模板解析](http://www.hmoore.net/zmwtp/tp5/120830)的分析
- 更新記錄
- 概述
- 文件索引
- 函數索引
- 章節格式
- 框架流程
- 前:章節說明
- 主:(index.php)入口
- 主:(start.php)框架引導
- 主:(App.php)應用啟動
- 主:(App.php)應用調度
- C:(Controller.php)應用控制器
- M:(Model.php)數據模型
- V:(View.php)視圖對象
- 附:(App.php)應用啟動
- 附:(base.php)全局變量
- 附:(common.php)模式配置
- 附:(convention.php)全局配置
- 附:(Loader.php)自動加載器
- 附:(Build.php)自動生成
- 附:(Hook.php)監聽回調
- 附:(Route.php)全局路由
- 附:(Response.php)數據輸出
- 附:(Log.php)日志記錄
- 附:(Exception.php)異常處理
- 框架工具
- 另:(helper.php)輔助函數
- 另:(Cache.php)數據緩存
- 另:(Cookie.php)cookie操作
- 另:(Console.php)控制臺
- 另:(Debug.php)開發調試
- 另:(Error.php)錯誤處理
- 另:(Url.php)Url操作文件
- 另:(Loader.php)加載器實例化
- 另:(Input.php)數據輸入
- 另:(Lang.php)語言包管理
- 另:(ORM.php)ORM基類
- 另:(Process.php)進程管理
- 另:(Session.php)session操作
- 另:(Template.php)模板解析
- 框架驅動
- D:(\config)配置解析
- D:(\controller)控制器擴展
- D:(\model)模型擴展
- D:(\db)數據庫驅動
- D:(\view)模板解析
- D:(\template)模板標簽庫
- D:(\session)session驅動
- D:(\cache)緩存驅動
- D:(\console)控制臺
- D:(\process)進程擴展
- T:(\traits)Trait目錄
- D:(\exception)異常實現
- D:(\log)日志驅動
- 使用范例
- 服務器與框架的安裝
- 控制器操作
- 數據模型操作
- 視圖渲染控制
- MVC開發初探
- 模塊開發
- 入口文件定義全局變量
- 運行模式開發
- 框架配置
- 自動生成應用
- 事件與插件注冊
- 路由規則注冊
- 輸出控制
- 多種應用組織
- 綜合應用
- tp框架整合后臺auto架構快速開發
- 基礎原理
- php默認全局變量
- php的魔術方法
- php命名空間
- php的自動加載
- php的composer
- php的反射
- php的trait機制
- php設計模式
- php的系統時區
- php的異常錯誤
- php的輸出控制
- php的正則表達式
- php的閉包函數
- php的會話控制
- php的接口
- php的PDO
- php的字符串操作
- php的curl
- 框架心得
- 心:整體結構
- 心:配置詳解
- 心:加載器詳解
- 心:輸入輸出詳解
- 心:url路由詳解
- 心:模板詳解
- 心:模型詳解
- 心:日志詳解
- 心:緩存詳解
- 心:控制臺詳解
- 框架更新
- 4.20(驗證類,助手函數)
- 4.27(新模型Model功能)
- 5.4(新數據庫驅動)
- 7.28(自動加載)