[請益] 建構子內函數回傳問題
關於建構子內的函數,若需要有值回傳。請問可以這麼用嗎?
有一 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://www.ptt.cc/bbs/PHP/M.1532398563.A.D83.html
→
07/24 11:04,
6年前
, 1F
07/24 11:04, 1F
→
07/24 11:05,
6年前
, 2F
07/24 11:05, 2F
→
07/24 11:05,
6年前
, 3F
07/24 11:05, 3F
謝謝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大~
→
07/24 11:59,
6年前
, 4F
07/24 11:59, 4F
→
07/24 12:13,
6年前
, 5F
07/24 12:13, 5F
→
07/24 12:15,
6年前
, 6F
07/24 12:15, 6F
→
07/24 12:16,
6年前
, 7F
07/24 12:16, 7F
→
07/24 12:16,
6年前
, 8F
07/24 12:16, 8F
!!! 原來有這東西!!謝謝M大指導!!
※ 編輯: goodsheng (118.163.89.30), 07/24/2018 13:25:40
→
07/24 13:54,
6年前
, 9F
07/24 13:54, 9F
→
07/24 13:55,
6年前
, 10F
07/24 13:55, 10F
→
07/24 13:56,
6年前
, 11F
07/24 13:56, 11F
→
07/24 13:59,
6年前
, 12F
07/24 13:59, 12F
→
07/25 01:20,
6年前
, 13F
07/25 01:20, 13F
→
07/25 01:21,
6年前
, 14F
07/25 01:21, 14F
→
07/25 01:22,
6年前
, 15F
07/25 01:22, 15F
→
07/25 01:24,
6年前
, 16F
07/25 01:24, 16F
→
07/25 01:25,
6年前
, 17F
07/25 01:25, 17F
→
07/25 01:29,
6年前
, 18F
07/25 01:29, 18F
→
07/25 14:52,
6年前
, 19F
07/25 14:52, 19F
→
07/25 14:52,
6年前
, 20F
07/25 14:52, 20F
對,其實一開始也不認為他會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
PHP 近期熱門文章
PTT數位生活區 即時熱門文章