php中按引用传递参数,如何通过PHP中的引用传递可变参数的参数?
假設有可能,通過引用變量函數來傳遞參數,而不會在
PHP中生成警告?我們不能再使用’&’運算符在函數調用中,否則我會接受(盡管這樣會很容易出錯,編碼器應該忘記它).
這是什么啟發是我發掘的舊的MySQLi包裝課程(這些天,我只是使用PDO).包裝器和MySQLi類之間的唯一區別是包裝器拋出異常而不是返回FALSE.
class DBException extends RuntimeException {}
...
class MySQLi_throwing extends mysqli {
...
function prepare($query) {
$stmt = parent::prepare($query);
if (!$stmt) {
throw new DBException($this->error, $this->errno);
}
return new MySQLi_stmt_throwing($this, $query, $stmt);
}
}
// I don't remember why I switched from extension to composition, but
// it shouldn't matter for this question.
class MySQLi_stmt_throwing /* extends MySQLi_stmt */ {
protected $_link, $_query, $_delegate;
public function __construct($link, $query, $prepared) {
//parent::__construct($link, $query);
$this->_link = $link;
$this->_query = $query;
$this->_delegate = $prepared;
}
function bind_param($name, &$var) {
return $this->_delegate->bind_param($name, $var);
}
function __call($name, $args) {
//$rslt = call_user_func_array(array($this, 'parent::' . $name), $args);
$rslt = call_user_func_array(array($this->_delegate, $name), $args);
if (False === $rslt) {
throw new DBException($this->_link->error, $this->errno);
}
return $rslt;
}
}
困難在于在包裝器上調用諸如bind_result的方法.可以明確定義恒定函數(例如bind_param),允許通過引用. bind_result,但是,需要所有參數都是通過引用.如果您在MySQLi_stmt_throwing的實例上調用bind_result,那么這些參數是通過值傳遞的,綁定將不會占用.
try {
$id = Null;
$stmt = $db->prepare('SELECT id FROM tbl WHERE ...');
$stmt->execute()
$stmt->bind_result($id);
// $id is still null at this point
...
} catch (DBException $exc) {
...
}
由于上述課程不再使用,這個問題只是一個好奇心.封裝類的替代方法是不相關的.定義一個使用Null默認值的一組參數的方法是不正確的(如果定義20個參數,但該函數是用21調用的).答案甚至不需要用MySQL_stmt_throwing的方式編寫;它僅僅是提供一個具體的例子.
總結
以上是生活随笔為你收集整理的php中按引用传递参数,如何通过PHP中的引用传递可变参数的参数?的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: php怎样解析数组,PHP 数组 Arr
- 下一篇: java ing印版,Java中有趣的事