<!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 "
";