1. 首先看下对clone后的对象操作是否会影响源对象;
直接上代码:
<?php
class test{
public $a = 1;
}
$testObject = new test();
echo '<pre>';
echo '没有clone操作前的源对象</br>';
var_dump($testObject);
$cloneTestObject = clone($testObject);
$cloneTestObject->a = 2;
echo 'clone操作后的源对象</br>';
var_dump($testObject);
echo 'clone操作后的clone对象</br>';
var_dump($cloneTestObject);
?>
结果:
//没有clone操作前的源对象
object(test)#1 (1) {
["a"]=>
int(1)
}
//clone操作后的源对象
object(test)#1 (1) {
["a"]=>
int(1)
}
//clone操作后的clone对象
object(test)#2 (1) {
["a"]=>
int(2)
}
结论:操作clone后的对象不会影响源对象;
2. 使用
对数据库操作时使用clone可以减少条件的重复书写;
如(以 ci 为例):
$this->db->where_in('key', $keys);
// clone $this->db对象;
$numDb = clone($this->db);
$this->db->order_by('created', desc);
$this->db->limit(10, 2);
$query = $this->db->get('users');
$userList = $query->result_array();
// 利用clone 后的$this->db对象获取符合条件的数据量,用户分页;
$this->db = $numDb;
$numQuery = $this->db->get('users');
$userCount = $numQuery->num_rows();