作者iamlilun (命好一生)
看板PHP
標題Re: [請益] Class中的constructor的小問題
時間Mon May 14 16:58:11 2018
※ 引述《jh961202 (阿電)》之銘言:
: 各位好,近日檢視自己以前撰寫的某個PHP程式,突然發現似乎有辦法可以優化
: 但試了一下發現好像不會work,不知道是不是哪裡有問題?
: 因此想在此請教各位好手,還請不吝提供意見
: ===================================================
: 此程式是某個個人撰寫的系統的引入檔(函數等等的集中處)
: 因為最初撰寫的時候學校正在教OOP,查詢PHP文件後發現PHP也支援OOP寫法
: 於是就弄出了這玩意,這樣也讓系統中調度功能比較方便
: 這個引入檔中含有幾個class,其中一個主要的用途是連線到資料庫並取得各式資訊
: 而資料庫的連線資訊是用private variable存放
: 並有多個public function可供呼叫,並且各自可從資料庫取回對應的資料
: 在此將架構大致舉例如下
: ---
: class ExampleClass {
: // 私有變數區
: private $sqlhost = "localhost" ;
: private $sqluser = "user" ;
: privare $sqlpass = "pass" ;
: // 以下都是函數
: public function FuncOne( $a, $b, $c ) {
: ...
: }
: public function FuncTwo( $a, $b, $c ) {
: ...
: }
: ...
: } // end class
: ---
: 近日,由於發現這些函數裡面有共同之處(主要是每個函數都要連線一次資料庫)
: 於是就想把這些地方拿出來,放在class一被呼叫時就執行的地方
: 理所當然地就想到了所謂的constructor,於是就生了一個出來
: 但卻發現就不會work了,原因是儲存連線的變數進不去其他的函數
: (本人用的作法是mysqli_connect()函數,雖然頗舊但都會work)
: 本人搜尋網路後,看到很多constructor都是OOP寫法
: 但不知道目前本人所用的procedural(也就是全部都用函數)的做法
: 能不能適用於這個地方呢?
: 還是說,我該捨棄這個做法,全部以OOP改寫才會work呢?
: 先謝謝各位解答及提點!
: p.s. 本人在試著寫constructor時,存mysql連線的變數有試著新增為public variable
: 但這樣依然不work
class ExampleClass {
// 私有變數區
private $sqlhost = "localhost";
private $sqluser = "user";
private $sqlpass = "pass";
private $dbName = 'dbname';
private $mysql;
public function __construct()
{
//初使mysql
$mysqli = new mysqli($this->sqlhost, $this->sqluser, $this->sqlpass, $this->dbName);
$mysqli->query("SET NAMES utf8");
$this->mysql = $mysqli;
}
public function __destruct() {
//結束連線
$this->mysql->close();
}
// 以下都是函數
public function FuncOne( $a, $b, $c )
{
$sql = " SELECT * from table_name where column_name='abcde'";
$result = $this->mysql->query($sql);
//....
}
public function FuncTwo( $a, $b, $c )
{
//...
}
} // end class
這樣行嗎??
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 122.201.164.235
※ 文章網址: https://webptt.com/m.aspx?n=bbs/PHP/M.1526288293.A.5F3.html