作者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/cn.aspx?n=bbs/PHP/M.1526288293.A.5F3.html