php物件導向知識點

weixin_34249678發表於2017-03-15

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
<title>test</title>
</head>
<body>
<?php
//interface關鍵字用於定義介面
//介面也可以使用extends關鍵字來繼承介面 當類實現子介面時,父介面定義的方法也需要在這個類裡面具體實現
//類的方法必須實現,介面的方法必須為空
//因為介面的實現方法可以有很多,所以對於介面裡面定義的方法的具體的實現是多種多樣的,這種特性我們稱為多型
//相同的一行程式碼,對於傳入不同的介面的實現的物件的時候,表現是不同的,這就是多型
interface iamliving{
//介面裡面的方法不需要有實現的方法
public function live();
}

//abstract關鍵字用於定義抽象類
abstract class animal{
//abstract關鍵字表示抽象方法,不需要實現
//繼承抽象類的子類需要實現抽象類中的抽象類方法
abstract public function eat($food);
}

//類的定義以關鍵詞class開始,後面跟名稱,通常第一個字母大寫,以中括號開始和結束
//implements關鍵字用於表示類實現某個介面
class Man implements iamliving{
//定義屬性
public $name="alex";
public $age=25;
public $sex="male";
//靜態屬性定義時在訪問控制關鍵字後加static關鍵字
public static $president="god";
public static function changePresident($newPresident){
//類中使用靜態成員時,用self關鍵字後面跟著::操作符,後面需要跟$符號 parent關鍵字訪問父類的靜態屬性
//靜態方法中不能訪問非靜態資料
self::$president=$newPresident;
}

//定義方法
//實現了某個介面之後,必須提供介面中定義的方法的具體實現
public function live(){
    echo "i am living";
}


public function run(){
    echo "running\n";
}

//final關鍵字能夠讓這個方法不能在子類中被重寫   final加在class前不允許類被繼承
final public function eat($food){
    echo $this->name."was eating".$food.'<br/>';
}

//建構函式在物件被例項化的時候呼叫
function __construct($name,$age,$sex){
    echo "建構函式被呼叫";
    //$this是php中偽變數,表示物件自身,可以通過$this->的方式訪問物件的屬性和方法
    $this->name=$name;
    $this->age=$age;
    $this->sex=$sex;
}
//解構函式,在程式執行結束的時候會自動呼叫
//通常用於清理程式使用的資源,比如程式使用了印表機,那麼可以在解構函式裡面釋放印表機資源
function __destruct(){
    echo $this->name."的解構函式被呼叫";
}

}
//類的例項化使用關鍵詞new,之後跟類的名稱和括號,用類名後面的引數列表初始化引數
$xiaoming=new Man("xiaoming",16,"male");

//類定義外部訪問靜態屬性,可以用類名加::操作符的方法來訪問類的靜態成員
Man::changePresident("fo");
echo Man::$president."
";

echo $xiaoming->name;
var_dump($xiaoming);
//$xiaoming=null 手動觸發解構函式
//當物件不會再使用時,會觸發解構函式

//extends關鍵字表示類的繼承,只能單繼承
class Student extends Man{
public $grade;
}

//可以用instanceof關鍵字來判斷某個物件是否實現了某個介面
var_dump($xiaoming instanceof iamliving);

/*
資料訪問
parent::關鍵字可以訪問父類中被子類重寫的方法
self::可以訪問自身的成員方法,也可用於訪問自身的靜態成員和類常量;不能用於訪問類自身的屬性;使用常量的時候不需要在常量名稱前新增$符號
static關鍵字用於訪問類自身定義的靜態成員,訪問靜態屬性的時候需要在屬性面前新增$符號
*/

//魔術方法
//__tostring() 當物件被當作string使用時,這個方法會被自動呼叫。 echo $obj
//__invoke() 當物件被當成方法呼叫時,這個方法會被自動呼叫 $obj(4)
//__call() 當物件訪問不存在的方法名稱時,該方法會被自動呼叫
//__callStatic() 當物件訪問不存在的靜態方法名稱時,該方法會被自動呼叫 這兩個方法在php裡面稱為方法的過載
/*
__get() __set() __isset() __unset
在給不可訪問的屬性賦值時,__set()會被呼叫
讀取不可訪問的的屬性的值時,__get()會被呼叫
當對不可訪問屬性呼叫isset()或empty()時,__isset()會被呼叫
當對不可訪問屬性呼叫unset()時,__unset()會被呼叫
所謂不可訪問屬性,實際上就是在呼叫某個屬性時發現這個屬性沒有被定義,這時候不同的操縱會觸發不同的魔術方法
這幾個方法也被稱為屬性過載的魔術方法

*/

class MagicTest{
public function __tostring(){
return "this is the class MagicTest";
}
public function __invoke($x){
echo "__invoke called with parameter".$x;
}
//方法的第一個引數是呼叫方法的名稱,第二個是方法呼叫的引數組成的陣列
public function __call($name,$argumengts){
echo "Calling".$name."with parameter:".implode(",",$argumengts);
}
public static function __callStatic($name,$argumengts){
echo "Calling".$name."with parameter:".implode(",",$argumengts);
}
public function __get($name){
return "getting the property ".$name;
}
public function __set($name,$value){
echo "setting the property ".$name." to value ".$value."
";
}
public function __isset($name){
echo "__isset invoked";
return true;
}
public function __unset($name){
echo "unsetting property ".$name."
";
}

}
$obj= new MagicTest();
echo $obj;
echo "
";
$obj(8);
echo "
";
$obj->runtest("one","two"."three");
echo "
";

相關文章