php中靜態方法的使用


靜態方法

(1)靜態方法不能訪問這個類中的普通屬性,因為那些屬性屬於一個對象,但可以訪問靜態屬性;

(2)從當前類(不是子類)中訪問靜態方法或屬性,可以使用 self 關鍵字,self 指向當前類,就像 $this  指向當前對象一樣;

(3)不能再對象中調用靜態方法,靜態方法和屬性又被稱為類方法和類屬性,因此不能再對象中使用偽變量 $this 。

靜態方法的優點:

(1)在代碼的任何地方都可以用(假設可以訪問該類);

(2)類的每個實例都可以訪問類中定義的靜態屬性,可以利用靜態屬性來設置值,該值可以被類的所有對象使用;

(3)不需要實例對象就能訪問靜態屬性或方法。

<?php $pdo = new PDO('mysql:host=localhost;dbname=mydb','root');  // 生成一個 PDO(PHP Data Object) 對象
class ShopProduct{ private $title;             // 屬性也稱為成員變量,用來存放對象之間互不相同的數據
    private $producerMainName;  // 所有的屬性都設置為 private,不允許外部直接訪問這些屬性,然后提供方法來取得需要的值
    private $producerFirstName; protected $price;           // 阻止外面直接訪問該屬性,可以被子類訪問
    private $discount = 0; private $id = 0; // 創建對象時,構造方法會被自動調用,構造方法可以確保必要的屬性設置,並完成任何需要准備的工作
    public function __construct($title,$mainName,$firstName,$price){ $this->title = $title;      // 使用偽變量$this給每個變量賦值
        $this->producerMainName = $mainName; $this->producerFirstName = $firstName; $this->price = $price; } /** * @return mixed 這種只返回屬性值的方法稱為“訪問方法”,也稱為 getter 和 setter */
    public function getProducerFirstName() { return $this->producerFirstName; } /** * @return mixed 獲取 姓 的訪問方法 */
    public function getProducerMainName() { return $this->producerMainName; } /** * @param $num 打折的價格 */
    public function setDiscount($num) { $this->discount = $num; } /** * @return int 折扣的訪問方法 */
    public function getDiscount() { return $this->discount; } /** * @return mixed Book名或CD名的訪問方法 */
    public function getTitle() { return $this->title; } /** * @return mixed 折扣后的價格 */
    public function getPrice() { return ($this->price - $this->discount); } /** * @return string 作者 */
    public function getProducer(){  // 方法讓對象執行任務
        return $this->producerMainName .' '. $this->producerFirstName; } /** * @return string 發票的摘要信息 */
    public function getSummaryLine() { $base = "{$this->title} ( {$this->producerMainName},{$this->producerFirstName}) "; return $base; } /** * @param $id id 的訪問方法, setter */
    public function setId($id) { $this->id = $id; } // 根據查詢數據的數據類型,返回特定類型的 ShopProduct 對象,這個方法沒有使用任何實例的屬性和方法,因此把它定義為一個靜態方法(static),只要有一個有效的 PDO 對象,就可以在程序的任何地方調用這個方法。這個方法就像工廠一樣,可以接受原始數據產生特定類型的對象。
    public static function getInstance($id,PDO $pdo) { $stmt = $pdo -> prepare("SELECT * FROM products WHERE id=?"); $stmt -> execute(array($id)); $row = $stmt -> fetch(); if(empty($row)){ return null; } switch($row['type']) { case 'book' :
                $product = new BookProduct($row['title'],$row['first_name'],$row['main_name'],$row['price'],$row['num_pages']); break; case 'cd' :
                $product = new CdProduct($row['title'],$row['first_name'],$row['main_name'],$row['price'],$row['play_length']); break; default :
                $product = new ShopProduct($row['title'],$row['first_name'],$row['main_name'],$row['price']); break; } $product -> setId($row['id']); $product -> setDiscount($row['discount']); return $product; } } // 若派生類沒有定義構造方法,則它在實例化是會自動調用父類的構造方法。子類默認繼承父類所有的 public 和 protected 方法,但不繼承 private 方法和屬性
class BookProduct extends ShopProduct { private $numPages; // 每個子類在設置自己的屬性前調用父類的構造方法,基類現在僅知道自己的數據,子類一般是父類的特列,應該避免告訴父類任何關於子類的消息。
    public function __construct($title,$mainName,$firstName,$price,$numPages) { // parent 關鍵字可以在任何復寫父類方法的方法中使用,通過在當前對象中調用父類的方法來拓展父類的功能 , 要應用一個類而不是對象的方法,使用 :: 而不是 ->
        parent::__construct($title,$mainName,$firstName,$price); $this -> numPages = $numPages; } /** * @param $numPages 書的頁數 * @return mixed 總頁數 */
    public function getNumberOfPages() { return $this->numPages; } /** * 子類(派生類)可以覆蓋和修改父類(基類或超類)的功能 * @return string Book發票的摘要信息 */
    public function getSummaryLine() { $base = parent::getSummaryLine(); $base .= "page count - {$this->numPages}"; return $base; } } class CdProduct extends ShopProduct { private $playLength; public function __construct($title,$mainName,$firstName,$price,$playLength) { parent::__construct($title,$mainName,$firstName,$price); $this -> playLength = $playLength; } /** * @return int 播放時間 */
    public function getPlayLength() { return $this -> playLength; } /** * @return string CD發票的摘要信息 */
    public function getSummaryLine() { $base = parent::getSummaryLine(); $base .= "playing time - {$this->playLength}"; return $base; } } $product = ShopProduct::getInstance(1,$pdo);     // 該靜態方法根據傳入 id 的不同生成特定類型的對象
if($product){ print "author : {$product -> getProducer()} </br>";              // author :Lun Xun
    print "summary line: {$product -> getSummaryLine()}</br>";      // summary line: Kong Yiji ( Xun,Lun) page count - 200
}

 附(sql 文件 和 數據的圖片):

本文是我閱讀了《深入PHP 面向對象、模式與實踐》一書的第四章中關於靜態方法和屬性的部分后所作

如有轉載,請注明出處:http://www.cnblogs.com/chrdai/p/6863090.html

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM