TP5.0 Redisシングルモード
多くの面接を见てデザインのモードを闻いて、私は简単に理解して、ついでに前にカプセル化したReisを一回修正しました.
シングルモード(Singleton Patternシングルモードまたはシングルエレメントモード)
単一のインスタンス・モードは、クラスに1つのインスタンスしかなく、独自にインスタンス化され、システム全体にこのインスタンスが提供されることを保証します.
シングル・インスタンス・モードには、次の3つの特徴があります.
1 . コンストラクション関数が必要であり、コンストラクション関数がプライベートである必要があります.
2.インスタンスを保存する静的メンバー変数が必要です
3.このインスタンスにアクセスする共通の静的メソッドを持つ
なぜ単例モードを使用するのですか?
PHPの主な応用場面はアプリケーションがデータベースと付き合うシーンであり、一つのアプリケーションには大量のデータベース操作が存在し、データベースハンドルがデータベースに接続される行為に対して、単例モードを使用すると大量のnew操作を避けることができる.new操作のたびにシステムとメモリのリソースが消費されるためです.
シングル・インスタンス・モードの下にあるコード:
ベースコントローラphp
RedisコントローラRedis.php
シングルモード(Singleton Patternシングルモードまたはシングルエレメントモード)
単一のインスタンス・モードは、クラスに1つのインスタンスしかなく、独自にインスタンス化され、システム全体にこのインスタンスが提供されることを保証します.
シングル・インスタンス・モードには、次の3つの特徴があります.
1 . コンストラクション関数が必要であり、コンストラクション関数がプライベートである必要があります.
2.インスタンスを保存する静的メンバー変数が必要です
3.このインスタンスにアクセスする共通の静的メソッドを持つ
なぜ単例モードを使用するのですか?
PHPの主な応用場面はアプリケーションがデータベースと付き合うシーンであり、一つのアプリケーションには大量のデータベース操作が存在し、データベースハンドルがデータベースに接続される行為に対して、単例モードを使用すると大量のnew操作を避けることができる.new操作のたびにシステムとメモリのリソースが消費されるためです.
シングル・インスタンス・モードの下にあるコード:
* Date: 2017/4/19
* Time: 16:21
*/
namespace My;
class RedisPackage
{
private static $handler = null;
private static $_instance = null;
private static $options = [
'host' => '127.0.0.1',
'port' => 6379,
'password' => '',
'select' => 0,
'timeout' => 0,
'expire' => 0,
'persistent' => false,
'prefix' => '',
];
private function __construct($options = [])
{
if (!extension_loaded('redis')) {
throw new \BadFunctionCallException('not support: redis'); //
}
if (!empty($options)) {
self::$options = array_merge(self::$options, $options);
}
$func = self::$options['persistent'] ? 'pconnect' : 'connect'; //
self::$handler = new \Redis;
self::$handler->$func(self::$options['host'], self::$options['port'], self::$options['timeout']);
if ('' != self::$options['password']) {
self::$handler->auth(self::$options['password']);
}
if (0 != self::$options['select']) {
self::$handler->select(self::$options['select']);
}
}
/**
* @return RedisPackage|null
*/
public static function getInstance()
{
if (!(self::$_instance instanceof self)) {
self::$_instance = new self();
}
return self::$_instance;
}
/**
*
*/
public function __clone()
{
trigger_error('Clone is not allow!',E_USER_ERROR);
}
/**
*
* @param string $key
* @param string $value
* @param int $exprie 0:
* @return bool
*/
public static function set($key, $value, $exprie = 0)
{
if ($exprie == 0) {
$set = self::$handler->set($key, $value);
} else {
$set = self::$handler->setex($key, $exprie, $value);
}
return $set;
}
/**
*
* @param string $key
* @return mixed
*/
public static function get($key)
{
$fun = is_array($key) ? 'Mget' : 'get';
return self::$handler->{$fun}($key);
}
/**
*
* @param string $key
* @return int
*/
public static function lLen($key)
{
return self::$handler->lLen($key);
}
/**
*
* @param $key
* @param $value
* @return int
*/
public static function LPush($key, $value)
{
return self::$handler->lPush($key, $value);
}
/**
*
* @param string $key
* @return string
*/
public static function lPop($key)
{
return self::$handler->lPop($key);
}
}
ベースコントローラphp
* Date: 2017/4/20
* Time: 14:39
*/
namespace app\index\controller;
use think\Controller;
use My\RedisPackage;
class Base extends Controller
{
protected static $redis;
public function __construct()
{
parent::__construct();
self::$redis=RedisPackage::getInstance();
}
}
RedisコントローラRedis.php
* Date: 2017/4/19
* Time: 14:39
*/
namespace app\index\controller;
use app\index\controller\Base;
class Redis extends Base
{
function redis()
{
self::$redis->set('Hello','World');
echo self::$redis->get('Hello');
}
}