国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

PHP OOP

imtianx / 2917人閱讀

摘要:使用了一段時間從對的不了解再到使用覺得挺好特寫下看面向對象我是看的這個雞啄米的并不是為了面向對象而面向對象而是為了達到代碼的重用性靈活性擴展性對象和類從先有對象才有人類這個來說有點不合理的合理類具有相同屬性的一組對象的集合對象類實例化之后就

PHP 使用了一段時間, 從對OOP的不了解, 再到使用, 覺得挺好, 特寫下

看面向對象, 我是看的這個雞啄米的c++, http://www.jizhuomi.com/softw...

OOP并不是為了面向對象而面向對象, 而是為了達到代碼的重用性靈活性擴展性

對象和類

從先有對象才有人類, 這個來說, 有點不合理的合理

類:具有相同屬性的一組對象的集合
對象:類實例化之后就是對象
看下一般的類的定義

name = $name;
        $this->age  = $age;
        $this->sex  = $sex;
    }
    // 析構函數
    function __destruct(){
        echo "byebye
";
    }
    // 成員方法
    function eat(){
        echo "my name is ". $this->name;
    }
    function sleep(){
        echo "i am sleeping";
    }
}
// 類的實例化
$jaime = new Person("jaime", "man", 24);
$jaime->eat();

?>

保存為index.php, 在命令窗口輸入

$ php index.php
my name is jaime
byebye

如果

$jaime = new Person("jaime", "man", 24);

改為

$jaime = new Person("jaime", "man");

則會觸發異常, 會有以下的消息出來, 包括錯誤信息, 錯誤行數, 和堆棧信息

$ php index.php

Fatal error: Uncaught exception "Exception" with message "must set name , sex, age" in E:
etindex.php on line 15

Exception: must set name , sex, age in E:
etindex.php on line 15

Call Stack:
    0.0025     242440   1. {main}() E:
etindex.php:0
    0.0025     243016   2. Person->__construct() E:
etindex.php:30
對象和內存

說點理論上的東西吧,

內存的分類:

堆(heap): 不可直接存取, 存儲占有空間很大的數據類型的數據

棧(stack): 可以直接存取, 存儲占用相同空間長度并且占用空間小的數據, 如存放局部變量,函數參數,當前狀態,函數調用信息等

$jaime = new Person("jaime", "man", 24);

$jaime是存放在棧內存里面的引用變量, 即存儲在堆中對象的首地址, 一個指針

new Person 實例化出來的對象是存放在堆內存里面的, 是真正的對象實例

對象和成員

變量,方法(內部成員函數)的前綴:

private: 私有成員

public: ?公有成員(外部接口),沒有加修飾, 默認就是public

protected: 保護型成員, 繼承的類可以調用

訪問private修飾的變量

Fatal error: Cannot access private property Person::$name in E:
etindex.php on line 36

如果想訪問private, protected修飾的成員:

把private改為public

使用__get(), ___set()魔術方法, 但是還是寫出代碼來看看根據實際情況使用

name = $name;
        $this->age  = $age;
        $this->sex  = $sex;
    }
    function __destruct(){
        echo "byebye
";
    }

    function eat(){
        echo "my name is ". $this->name."
";
    }
    function sleep(){
        echo "i am sleeping
";
    }

    function __get($property_name){
        $access_array = ["age","name"];// 只允許訪問age,name兩個私有成員
        if(in_array($property_name, $access_array)){
            return ($this->$property_name);
        }
        else{
            return NULL;
        }
    }
    function __set($property_name, $value){
        $access_array = ["age"];// 只允許訪問age這個私有成員
        if(in_array($property_name, $access_array)){
            $this->$property_name = $value;
        }
    }

}

$jaime = new Person("jaime", "man", 24);
$jaime->eat();
echo ($jaime->age === NULL)? "NULL":$jaime->age;
echo "
";
echo ($jaime->sex === NULL)? "NULL":$jaime->sex;
$jaime->age = 80;
echo "
";
echo ($jaime->age === NULL)? "NULL":$jaime->age;
echo "
";
$jaime->name = "lll";
echo ($jaime->name === NULL)? "NULL":$jaime->name;
echo "
";
?>

執行結果如下

$ php index.php
my name is jaime
24
NULL
80
jaime
byebye
類的繼承
name = $name;
        $this->age  = $age;
        $this->sex  = $sex;
    }
    function __destruct(){
        echo "byebye
";
    }

    function hello(){
        echo "my name is ". $this->name."
";
    }
    function sleep(){
        echo "i am sleeping
";
    }
}


class Student extends Person
{
    private $school;

    function __construct($name, $sex, $age, $school)
    {
        // 調用父類方法, 構造函數
        parent::__construct($name, $sex, $age);
        $this->school = $school;
    }
    // 重載了父類方法
    function sleep(){
        echo "afternoon sleep
";
        // 調用父類方法
        parent::sleep();
    }
}

$jaime = new Student("jaime", "man", 24,"zh");
$jaime->hello();
$jaime->sleep();
?>

執行后輸出

$ php index.php
my name is jaime
afternoon sleep
i am sleeping

byebye

調用父類的方法需要用parent

靜態成員和常量

no bb, show code

show();
?>

結果

$ php is.php
China
 en
I live in China
I live in American
xxxAmerican en

類的靜態變量,類似于全局變量,能夠被所有類的實例共享,類的靜態方法也是一樣的,類似于全局函數, 靜態成員被這個類的每個實例對象所共享

訪問靜態方法訪問靜態成員不能用$this, 需要用self

$this表示了此方法的對象

"self"表示此靜態方法所在的類, self::成員

抽象方法和抽象類

什么叫抽象?不具體的就叫抽象! so

抽象方法 : 類里面沒有具體方法體的方法(其實就是不具體的方法)

抽象類: 含有抽象方法的類,

抽象類不能實例化會報錯"Cannot instantiate abstract class ", 有點像C里面的函數聲明, 僅僅只是一個聲明

fun1();
(new demo0())->fun2();
(new demo0())->fun3();
?>
接口interface 什么是接口?

如果一個內里面所有的方法都是抽象方法, 我們可以把聲明方式換為接口

接口是一種特殊的抽象類, 接口不能包含成員的任何代碼,只定義成員身。接口成員的具體代碼由實現接口的類提供

接口的繼承
接口的實現
fun1();
(new demo())->fun2();
(new demo())->fun3();
(new demo())->fun4();
?>
一個類實現多個接口

一個人要遵守的法律不止一步吧, 所以see code

fun1();
(new demo())->fun2();
(new demo())->fun3();
(new demo())->fun4();
?>

你娶了你老婆你得對她的家人負責吧, 就像下面

// 使用extends繼承一個類,使用implements實現多個接口
class demo extend AbstractClass implements One, Two{
    ......
    // 所有接口中的方法都要實現才可以實例化對象
}
反射Reflection

需求: 導出或提取出關于類、方法、屬性、參數等的詳細信息, 甚至是判斷某個方法是否存在
這里我不做多說, 看我在實際的項目中的實際應用,
這是一個API的入口處理函數, 如果存在這個方法就執行并返回結果, 不存在就拋出異常,
因為接口函數是不斷增加甚至是變化的, 使用反射作為api的入口可以讓你的具體的api函數變化了入口也不用改

try {
    // 使用工廠方法實例化具體的接口
    $instance = new ApiLibraryApiFactory($module, $server, $this->params);
    // 反射方法
    $action   = new ReflectionMethod($instance->instance, $method);
    // 判斷方法的類型
    if (!$action->isPublic() || $action->isStatic()) throw new ReflectionException();
    // 驗證api參數
    $validator = new ApiLibraryApiValidator();
    $result    = $validator->check($this->params);
    if (false === $result)  {
        $this->result["code"] = $validator->code ? : $this->result["code"];
        $this->result["msg"]  = $validator->msg  ? : $this->result["msg"];
        throw new Exception();
    }
} catch(Exception $e){
    $this->_format();
}

參考:

《細說PHP 》 兄弟連

《PHP手冊》

《php面向對象(OOP)編程完全教程》

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/21681.html

相關文章

  • Learning PHP —— 設計模式 | Chap1:淺談設計模式中的OOP

    摘要:而哈士奇區別于普通狗,又有新的特征逗比,愛搗亂為了保證類之間的松綁定,通常會繼承抽象類,而且是淺繼承只有一層子類。如果知道所有類都會共享一個公共的行為實現,就使用抽象類,并在其中實現該行為。 為什么使用OOP OOP是一個模塊化的過程,目的是為了把復雜問題簡單化,一個模塊解決一個復雜問題的某一個方面,即一個類應當只有一個職責 OOP區別于順序式編程與過程式編程,在于: 1.順序編程...

    SunZhaopeng 評論0 收藏0
  • PHP面向對象(OOP)----分頁類

    摘要:男獲取端口號當前運行腳本所在的服務器的主機名。如果腳本運行于虛擬主機中,該名稱是由那個虛擬主機所設置的值決定本文由甲爪廣告聯盟整理編輯 同驗證碼類,分頁也是在個人博客,論壇等網站中不可缺少的方式,通過分頁可以在一個界面展示固定條數的數據,而不至于將所有數據全部羅列到一起,實現分頁的原理其實就是對數據庫查詢輸出加了一個limit限制,接下來我們就開始準備今天分頁類的邏輯 #### 邏輯準...

    qqlcbb 評論0 收藏0
  • 成為一個PHP專家:缺失的環節

    摘要:為了成為一個專家,他必須先成為中級者。它非常適合于急于求成或者沒有太多技術的人,但掌握絕對無法使你成為一個專業的開發者它使用意大利面條式的編碼,教你的是不合適的設計原則。 這一篇文章是Becoming a PHP Professional系列 4 篇博文中的第 1 篇。 當瀏覽各類與PHP相關的博客時,比如Quora上的問題,谷歌群組,簡訊和雜志,我經常注意到技能的等級分化。問題都類...

    cooxer 評論0 收藏0
  • 我的 PHP 學習路線

    摘要:我的學習路線入門入門沒啥好說的,會基本編碼,基本的開發結構通常指,呵呵噠,類與對象,就差不多了,可以說是入門了。在這些已有基礎,我們需要學習并且還需要學會各種推陳出新,這樣才可以讓自己讓他人走得更遠。 我的 PHP 學習路線 1. PHP 入門 PHP 入門沒啥好說的,會基本編碼,基本的開發結構(通常指MVC,呵呵噠),類與對象,就差不多了,可以說是入門了。 1.1 OOP 寫 PHP...

    zhunjiee 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<