作者goodsheng (恩哈哈)
看板PHP
標題[請益] 建構子內函數回傳問題
時間Tue Jul 24 10:16:00 2018
關於建構子內的函數,若需要有值回傳。請問可以這麼用嗎?
有一 config.php
==============================
<?php
class config {
function __construct() {
$this->getvalue();
}
function getvalue() {
echo 'log'; //埋確定有進入函數的log
return 10;
}
}
?>
==============================
然後我在主php去引用並使用config.php,想要得到裡面getvalue的回傳值。
但卻無法得到..,請問可能原因為何?
main.php
===========================================
<?php
require_once __DIR__ . '/config.php';
$value = new config();
echo $value;
?>
===========================================
echo 只會得到 'log'卻無法得到 return的值(10)
還是說其實問不能樣用呢,剛初學請各位大大幫忙,謝謝..
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 118.163.89.30
※ 文章網址: https://webptt.com/m.aspx?n=bbs/PHP/M.1532398563.A.D83.html
1F:→ MOONRAKER: 這是當然的好嗎,constructor不回傳東西 07/24 11:04
2F:→ MOONRAKER: 你有什麼理由非要這樣 連多呼叫一個$value->getValue() 07/24 11:05
3F:→ MOONRAKER: 都不想嗎 07/24 11:05
謝謝M大回覆~沒錯我去多呼叫可以解決!!
問題原由是因為我在處理連結資料庫的時候,有出現有連上,但無法query問題。
細找問題後,發現CONNECT根本沒有回傳,所以才衍生出這樣的提問。
https://blog.csdn.net/welovesunflower/article/details/7776438
裡面範例他有一個 db_connect.php ,相較於我上頭的config.php,準備提供引入用。
內容有斷如下:
class DB_CONNECT {
// constructor
function __construct() {
// connecting to database
$this->connect(); //這裡用了類似作法
}
function connect() {
// import database connection variables
require_once __DIR__ . '/db_config.php';
// Connecting to mysql database
$con = mysql_connect(DB_SERVER, DB_USER, DB_PASSWORD) ...;
....
// returing connection cursor
return $con; //回傳connect //這裡用了類似作法
}
再來範例裡面有一個 get_all_products.php,相較於我的main.php,
裡面開頭如下:
==============================================
...
// include db connect class
require_once __DIR__ . '/db_connect.php';
// connecting to db
$db = new DB_CONNECT(); //此處根本沒有得到值。
// get all products from products table
$result = mysql_query("SELECT *FROM products") or die(mysql_error())
...
==============================================
$db因為沒有得到值,所以query不到。
當然如您建議我加個 $con = $db->connect(); 就沒問題了。
所以是不是其實真不該這樣寫呢?
應該明瞭了!!! 觀念問題,謝謝M大~
4F:→ MOONRAKER: 這樣我就看不懂了 為什麼他的資料庫包裝會這樣 07/24 11:59
5F:→ MOONRAKER: 一時想不通 但是什麼時候了還在用mysql_connect()這種 07/24 12:13
6F:→ MOONRAKER: 爛招 新的php早就沒了 new會跑不出東西八成是這個原因 07/24 12:15
7F:→ MOONRAKER: 趕快找個教用pdo連資料庫的文件來看吧 起碼也要mysqli 07/24 12:16
8F:→ MOONRAKER: 依照他這種爛招 再connect()一次也沒有東西 07/24 12:16
!!! 原來有這東西!!謝謝M大指導!!
※ 編輯: goodsheng (118.163.89.30), 07/24/2018 13:25:40
10F:→ MOONRAKER: 從php 5.5開始廢棄 7.0拿掉 如今php 7.2都出了 07/24 13:55
11F:→ MOONRAKER: WAMP一類套件包當然不會再放舊的 雖然你要也是找得到 07/24 13:56
12F:→ goodsheng: 好的!! mysqli或是PDO處理 07/24 13:59
13F:→ xdraculax: $db 得到了 class 啊,return 是供額外呼叫用 07/25 01:20
14F:→ xdraculax: 它的 __construct 也沒有 return $this->connect() 07/25 01:21
15F:→ xdraculax: 你怎麼會誤以為它 $db 是想取 $con 07/25 01:22
16F:→ xdraculax: mysql_query 沒代入 con 就是預設上一個連線 07/25 01:24
17F:→ xdraculax: 範例並沒有錯應該要有資料,沒資料一定是別的有錯 07/25 01:25
18F:→ xdraculax: 以上指正你 new class 的誤解而非說可繼續用 mysql_xx 07/25 01:29
19F:→ MOONRAKER: 有啦昨晚有想出來 他是佔mysql_query()沒給連線物件 07/25 14:52
20F:→ MOONRAKER: 就自動沿用最近那個的便宜 實在不可取 07/25 14:52
對,其實一開始也不認為他會return東西,因為他mysql_query並沒有要帶入$con。
而照理說接下來的操作應該要沿用所謂"預設上一個連線"
但實作後卻發現並沒有,他並沒有延用到,所以mysql接下來操作都沒有反應。
所以我就天真自己加了$db進去,天真以為$db有東西。
$result = mysql_query($db,"SELECT *FROM products") or die(mysql_error())
想當然沒反應,$db不會有東西,因為如x大解說,return不回東西的。
但後來解決方式是再呼叫一次connect(),且也要帶入$con,才能成功,沒帶入不行。
$con = $db->connect();
$result = mysql_query($con,"SELECT *FROM products") or die(mysql_error())
所以才會有建構內return的疑問..
所以現在衍生的問題是:
1.一開始的方式,由建構來初始連線,但回主程式時,卻無法直接沿用後連線。
2.後來改再次呼叫connect()的方式,看起來也是無延續上一連線。必須要帶入$con。
看起來好像是同一問題,就副程式實體後的連線無法給主程式用?
但這問題可能也不是很重要,因為可以先用了.. (註:上述mysql我也都改成mysqli用了)
再次謝謝x大及M大~~
※ 編輯: goodsheng (118.163.89.30), 07/26/2018 16:05:02