0 追蹤者

類別 yii\caching\MemCacheServer

繼承關係yii\caching\MemCacheServer » yii\base\BaseObject
實作yii\base\Configurable
自版本起可用2.0
原始碼 https://github.com/yiisoft/yii2/blob/master/framework/caching/MemCacheServer.php

MemCacheServer 代表單個 memcache 或 memcached 伺服器的配置資料。

請參閱 PHP 手冊 以取得每個配置屬性的詳細說明。

如需快取的更多詳細資訊和使用方法,請參閱快取概觀指南文章

公開屬性

隱藏繼承的屬性

屬性 類型 描述 定義於
$failureCallback 閉包(Closure) 當遇到錯誤時,將會執行此回呼函式。 yii\caching\MemCacheServer
$host 字串 Memcache 伺服器主機名稱或 IP 位址 yii\caching\MemCacheServer
$persistent 布林值 是否使用持久連線。 yii\caching\MemCacheServer
$port 整數 Memcache 伺服器埠號 yii\caching\MemCacheServer
$retryInterval 整數 失敗的伺服器將被重新嘗試的頻率(秒)。 yii\caching\MemCacheServer
$status 布林值 如果伺服器在發生故障時應標記為在線。 yii\caching\MemCacheServer
$timeout 整數 連線至伺服器的逾時時間,以毫秒為單位。 yii\caching\MemCacheServer
$weight 整數 在所有伺服器中,使用此伺服器的機率。 yii\caching\MemCacheServer

公開方法

隱藏繼承的方法

方法 描述 定義於
__call() 呼叫指定的非類別方法。 yii\base\BaseObject
__construct() 建構子。 yii\base\BaseObject
__get() 傳回物件屬性的值。 yii\base\BaseObject
__isset() 檢查屬性是否已設定,即已定義且非 null。 yii\base\BaseObject
__set() 設定物件屬性的值。 yii\base\BaseObject
__unset() 將物件屬性設定為 null。 yii\base\BaseObject
canGetProperty() 傳回值,指示屬性是否可讀取。 yii\base\BaseObject
canSetProperty() 傳回值,指示屬性是否可設定。 yii\base\BaseObject
className() 傳回此類別的完整命名空間名稱。 yii\base\BaseObject
hasMethod() 傳回值,指示方法是否已定義。 yii\base\BaseObject
hasProperty() 傳回值,指示屬性是否已定義。 yii\base\BaseObject
init() 初始化物件。 yii\base\BaseObject

屬性詳細資訊

隱藏繼承的屬性

$failureCallback 公開屬性

當遇到錯誤時,將會執行此回呼函式。此回呼會在嘗試故障轉移之前執行。此函式接受兩個參數,即失敗伺服器的 $host$port。這僅由 memcache 使用。

public Closure $failureCallback null
$host 公開屬性

Memcache 伺服器主機名稱或 IP 位址

public string $host null
$persistent 公開屬性

是否使用持久連線。這僅由 memcache 使用。

public boolean $persistent true
$port 公開屬性

Memcache 伺服器埠號

public integer $port 11211
$retryInterval 公開屬性

失敗的伺服器將被重新嘗試的頻率(秒)。這僅由 memcache 使用。

public integer $retryInterval 15
$status 公開屬性

如果伺服器在發生故障時應標記為在線。這僅由 memcache 使用。

public boolean $status true
$timeout 公開屬性

連線至伺服器的逾時時間,以毫秒為單位。這僅由 memcache 使用。對於僅支援以秒為單位指定逾時時間的舊版 memcache,這將四捨五入為整秒。

public integer $timeout 1000
$weight 公開屬性

在所有伺服器中,使用此伺服器的機率。

public integer $weight 1

方法詳細資訊

隱藏繼承的方法

__call() 公開方法

定義於: yii\base\BaseObject::__call()

呼叫指定的非類別方法。

請勿直接呼叫此方法,因為當調用未知方法時,它將被隱式呼叫,作為 PHP 魔術方法。

public mixed __call ( $name, $params )
$name 字串

方法名稱

$params 陣列

方法參數

return 混合

方法傳回值

throws yii\base\UnknownMethodException

當呼叫未知方法時

                public function __call($name, $params)
{
    throw new UnknownMethodException('Calling unknown method: ' . get_class($this) . "::$name()");
}

            
__construct() 公開方法

定義於: yii\base\BaseObject::__construct()

建構子。

預設實作執行兩件事

  • 使用給定的組態 $config 初始化物件。
  • 呼叫 init()

如果此方法在子類別中被覆寫,建議

  • 建構子的最後一個參數是一個組態陣列,例如此處的 $config
  • 在建構子的結尾呼叫父類別實作。
public void __construct ( $config = [] )
$config 陣列

將用於初始化物件屬性的名稱-值對

                public function __construct($config = [])
{
    if (!empty($config)) {
        Yii::configure($this, $config);
    }
    $this->init();
}

            
__get() 公開方法

定義於: yii\base\BaseObject::__get()

傳回物件屬性的值。

請勿直接呼叫此方法,因為當執行 $value = $object->property; 時,它將被隱式呼叫,作為 PHP 魔術方法。

另請參閱 __set()

public mixed __get ( $name )
$name 字串

屬性名稱

return 混合

屬性值

throws yii\base\UnknownPropertyException

如果屬性未定義

throws yii\base\InvalidCallException

如果屬性為唯寫

                public function __get($name)
{
    $getter = 'get' . $name;
    if (method_exists($this, $getter)) {
        return $this->$getter();
    } elseif (method_exists($this, 'set' . $name)) {
        throw new InvalidCallException('Getting write-only property: ' . get_class($this) . '::' . $name);
    }
    throw new UnknownPropertyException('Getting unknown property: ' . get_class($this) . '::' . $name);
}

            
__isset() 公開方法

定義於: yii\base\BaseObject::__isset()

檢查屬性是否已設定,即已定義且非 null。

請勿直接呼叫此方法,因為當執行 isset($object->property) 時,它將被隱式呼叫,作為 PHP 魔術方法。

請注意,如果屬性未定義,將傳回 false。

另請參閱 https://php.dev.org.tw/manual/en/function.isset.php

public boolean __isset ( $name )
$name 字串

屬性名稱或事件名稱

return 布林值

指定的屬性是否已設定(非 null)。

                public function __isset($name)
{
    $getter = 'get' . $name;
    if (method_exists($this, $getter)) {
        return $this->$getter() !== null;
    }
    return false;
}

            
__set() 公開方法

定義於: yii\base\BaseObject::__set()

設定物件屬性的值。

請勿直接呼叫此方法,因為當執行 $object->property = $value; 時,它將被隱式呼叫,作為 PHP 魔術方法。

另請參閱 __get()

public void __set ( $name, $value )
$name 字串

屬性名稱或事件名稱

$value 混合

屬性值

throws yii\base\UnknownPropertyException

如果屬性未定義

throws yii\base\InvalidCallException

如果屬性為唯讀

                public function __set($name, $value)
{
    $setter = 'set' . $name;
    if (method_exists($this, $setter)) {
        $this->$setter($value);
    } elseif (method_exists($this, 'get' . $name)) {
        throw new InvalidCallException('Setting read-only property: ' . get_class($this) . '::' . $name);
    } else {
        throw new UnknownPropertyException('Setting unknown property: ' . get_class($this) . '::' . $name);
    }
}

            
__unset() 公開方法

定義於: yii\base\BaseObject::__unset()

將物件屬性設定為 null。

請勿直接呼叫此方法,因為當執行 unset($object->property) 時,它將被隱式呼叫,作為 PHP 魔術方法。

請注意,如果屬性未定義,此方法將不執行任何操作。如果屬性為唯讀,它將拋出例外。

另請參閱 https://php.dev.org.tw/manual/en/function.unset.php

public void __unset ( $name )
$name 字串

屬性名稱

throws yii\base\InvalidCallException

如果屬性為唯讀。

                public function __unset($name)
{
    $setter = 'set' . $name;
    if (method_exists($this, $setter)) {
        $this->$setter(null);
    } elseif (method_exists($this, 'get' . $name)) {
        throw new InvalidCallException('Unsetting read-only property: ' . get_class($this) . '::' . $name);
    }
}

            
canGetProperty() 公開方法

定義於: yii\base\BaseObject::canGetProperty()

傳回值,指示屬性是否可讀取。

如果符合以下任一條件,則屬性可讀取:

  • 類別具有與指定名稱相關聯的 getter 方法(在這種情況下,屬性名稱不區分大小寫);
  • 類別具有具有指定名稱的成員變數(當 $checkVars 為 true 時);

另請參閱 canSetProperty()

public boolean canGetProperty ( $name, $checkVars true )
$name 字串

屬性名稱

$checkVars 布林值

是否將成員變數視為屬性

return 布林值

屬性是否可讀取

                public function canGetProperty($name, $checkVars = true)
{
    return method_exists($this, 'get' . $name) || $checkVars && property_exists($this, $name);
}

            
canSetProperty() 公開方法

定義於: yii\base\BaseObject::canSetProperty()

傳回值,指示屬性是否可設定。

如果符合以下條件,則屬性可寫入:

  • 類別具有與指定名稱相關聯的 setter 方法(在這種情況下,屬性名稱不區分大小寫);
  • 類別具有具有指定名稱的成員變數(當 $checkVars 為 true 時);

另請參閱 canGetProperty()

public boolean canSetProperty ( $name, $checkVars true )
$name 字串

屬性名稱

$checkVars 布林值

是否將成員變數視為屬性

return 布林值

屬性是否可寫入

                public function canSetProperty($name, $checkVars = true)
{
    return method_exists($this, 'set' . $name) || $checkVars && property_exists($this, $name);
}

            
className() 公開靜態方法
自 2.0.14 版本起已棄用。在 PHP >=5.5 上,請改用 ::class

定義於: yii\base\BaseObject::className()

傳回此類別的完整命名空間名稱。

public static string className ( )
return 字串

此類別的完整命名空間名稱。

                public static function className()
{
    return get_called_class();
}

            
hasMethod() 公開方法

定義於: yii\base\BaseObject::hasMethod()

傳回值,指示方法是否已定義。

預設實作是對 php 函式 method_exists() 的呼叫。當您實作 php 魔術方法 __call() 時,您可以覆寫此方法。

public boolean hasMethod ( $name )
$name 字串

方法名稱

return 布林值

方法是否已定義

                public function hasMethod($name)
{
    return method_exists($this, $name);
}

            
hasProperty() 公開方法

定義於: yii\base\BaseObject::hasProperty()

傳回值,指示屬性是否已定義。

如果符合以下任一條件,則屬性已定義:

  • 類別具有與指定名稱相關聯的 getter 或 setter 方法(在這種情況下,屬性名稱不區分大小寫);
  • 類別具有具有指定名稱的成員變數(當 $checkVars 為 true 時);

另請參閱

public boolean hasProperty ( $name, $checkVars true )
$name 字串

屬性名稱

$checkVars 布林值

是否將成員變數視為屬性

return 布林值

屬性是否已定義

                public function hasProperty($name, $checkVars = true)
{
    return $this->canGetProperty($name, $checkVars) || $this->canSetProperty($name, false);
}

            
init() 公開方法

定義於: yii\base\BaseObject::init()

初始化物件。

在物件使用給定的組態初始化後,此方法會在建構子的結尾被調用。

public void init ( )

                public function init()
{
}