Maison > développement back-end > tutoriel php > 关于单列模式和内存相关的

关于单列模式和内存相关的

WBOY
Libérer: 2016-06-06 20:25:07
original
1229 Les gens l'ont consulté

一、单例模式可以保证一个对象只实例化一次,这个我该怎么理解呢?是A用户本次请求在这个进程中只是实例化一次还是A用户实例化以后,B用户在来访问时如果A实例化也是用的A的,如果是按后者来说的话,那如下代码也就是说数据库的连接数只是一个咯?不是吧?(如下代码)

class nmdb
{

<code>private $link;
static private $_instance;
// 连接数据库
private function __construct($host, $username, $password)
{
    $this->link = mysql_connect($host, $username, $password);
    $this->query("SET NAMES 'utf8'", $this->link);
    //echo mysql_errno($this->link) . ": " . mysql_error($link). "n";
    //var_dump($this->link);
    return $this->link;
}

private function __clone(){}

public static function get_class_nmdb($host, $username, $password)
{
    //$connector = new nmdb($host, $username, $password);
    //return $connector;
    
    if( FALSE == (self::$_instance instanceof self) )
    {
        self::$_instance = new self($host, $username, $password);
    }
    return self::$_instance;
}

// 连接数据表
public function select_db($database)
{
    $this->result = mysql_select_db($database);
    return $this->result;
}

// 执行SQL语句
public function query($query)
{
    return $this->result = mysql_query($query, $this->link);
}

// 将结果集保存为数组
public function fetch_array($fetch_array)
{
    return $this->result = mysql_fetch_array($fetch_array, MYSQL_ASSOC);
}

// 获得记录数目
public function num_rows($query)
{
    return $this->result = mysql_num_rows($query);
}

// 关闭数据库连接
public function close()
{
    return $this->result = mysql_close($this->link);
}
</code>
Copier après la connexion
Copier après la connexion

}
?>

回复内容:

一、单例模式可以保证一个对象只实例化一次,这个我该怎么理解呢?是A用户本次请求在这个进程中只是实例化一次还是A用户实例化以后,B用户在来访问时如果A实例化也是用的A的,如果是按后者来说的话,那如下代码也就是说数据库的连接数只是一个咯?不是吧?(如下代码)

class nmdb
{

<code>private $link;
static private $_instance;
// 连接数据库
private function __construct($host, $username, $password)
{
    $this->link = mysql_connect($host, $username, $password);
    $this->query("SET NAMES 'utf8'", $this->link);
    //echo mysql_errno($this->link) . ": " . mysql_error($link). "n";
    //var_dump($this->link);
    return $this->link;
}

private function __clone(){}

public static function get_class_nmdb($host, $username, $password)
{
    //$connector = new nmdb($host, $username, $password);
    //return $connector;
    
    if( FALSE == (self::$_instance instanceof self) )
    {
        self::$_instance = new self($host, $username, $password);
    }
    return self::$_instance;
}

// 连接数据表
public function select_db($database)
{
    $this->result = mysql_select_db($database);
    return $this->result;
}

// 执行SQL语句
public function query($query)
{
    return $this->result = mysql_query($query, $this->link);
}

// 将结果集保存为数组
public function fetch_array($fetch_array)
{
    return $this->result = mysql_fetch_array($fetch_array, MYSQL_ASSOC);
}

// 获得记录数目
public function num_rows($query)
{
    return $this->result = mysql_num_rows($query);
}

// 关闭数据库连接
public function close()
{
    return $this->result = mysql_close($this->link);
}
</code>
Copier après la connexion
Copier après la connexion

}
?>

PHP-FPM 机制是每个请求完毕后释放所有资源,包括数据库实例。

所以PHP-FPM下每个请求都会实例化一次数据库实例。A用户的请求和B用户的请求使用的是不同的数据库实例。

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal