本文實例匯總了PHP面向對象程序設計的精要。分享給大家供大家參考。具體分析如下:
1 使用extends實現繼承以及重載、魔術方法的含義
class B extends A
聲明的時候B裡可以沒有A裡的方法
調用的時候:
$b=new B();
$b->A裡的方法();
$b->A裡的屬性=1;
$b->B裡的方法();
$b->B裡的方法();
如果$a=new A();
可以
$a->A裡的方法();
$a->A裡的屬性=1;
不可以
$a->B裡的方法();
$a->B裡的方法();
重載:B繼承A ,B裡實現和A同名的方法屬性。
PHP中的"重載"與其它絕大多數面向對象語言不同。傳統的"重載"是用於提供多個同名的 類方法,但各方法的參數類型和個數不同。
魔術方法:PHP把所有以__(兩個下劃線)開頭的類方法當成魔術方法。所以你定義自己的類方法時,不要以 __為前綴。
2 繼承用private和protected訪問修飾符可見性
屬性方法private不可以被繼承
屬性方法protected類外部不可見,可以被繼承
屬性方法public 所定義的類成員可以在任何地方被訪問
3 php中雙冒號::的應用
php類代碼中常看到"::"的操作符,這個是作用域限定操作符,是用一個雙冒號"::"表示,它用來置頂類中不同作用域的級別。左邊是作用域右邊是訪問作用域的成員。
在php中定義的作用域有self和parent兩種(在php6中提供了static作用域)。
范圍解析操作符(也可稱作 Paamayim Nekudotayim)或者更簡單地說是一對冒號,可以用於訪問靜態成員、方法和常量,還可以用於子類覆蓋父類中的成員和方法。
復制代碼 代碼如下:class MyClass {
const CONST_VALUE = 'A constant value';
}
echo MyClass::CONST_VALUE;
class OtherClass extends MyClass
{
public static $my_static = 'static var';
public static function doubleColon() {
echo parent::CONST_VALUE . "\n";
echo self::$my_static . "\n";
}
}
OtherClass::doubleColon();
//子類覆蓋父類
class MyClass
{
protected function myFunc() {
echo "MyClass::myFunc()\n";
}
}
class OtherClass extends MyClass
{
// 覆蓋父類中的方法
public function myFunc()
{
// 但仍然可以調用已被覆蓋的方法
parent::myFunc();
echo "OtherClass::myFunc()\n";
}
}
$class = new OtherClass();
$class->myFunc();
4 php中this和self以及parent的作用
this:就是指向當前對象實例的指針,不指向任何其他對象或類。
self:表示當前類的作用域,與this不同的是它不表示類的某個特定實例,在類之外的代碼中不能使用self,而且它不能識別自己在繼承中層次的位置。也就是說,當在擴展類中使用self時,它調用的不是父類的方法,而是擴展類的重載的方法。self是指向類本身,也就是self是不指向任何已經實例化的對象,一般self使用來指向類中的靜態變量。
復制代碼 代碼如下:private static $firstCount = 0;
private $lastCount;
//構造函數
function __construct()
{
$this->lastCount = ++self:$firstCount; //使用self來調用靜態變量,使用self調用必須使用::(域運算符號)
}
parent:表示當前類父類的作用域,其余的跟self特性一樣。parent是指向父類的指針,一般我們使用parent來調用父類的構造函數。
復制代碼 代碼如下://繼承類的構造函數
function __construct( $personSex, $personAge )
{
parent::__construct( "test" ); //使用parent調用了父類的構造函數
$this->personSex = $personSex;
$this->personAge = $personAge;
}
5 構造函數與析構函數
具有構造函數的類會在每次創建對象時先調用此方法,所以非常適合在使用對象之前做一些初始化工作。
function __construct() {}
如果子類中定義了構造函數則不會暗中調用其父類的構造函數。要執行父類的構造函數,需要在子類的構造函數中調用 parent::__construct()。
PHP 5 引入了析構函數的概念,這類似於其它面向對象的語言,如 C++。析構函數會在到某個對象的所有引用都被刪除或者當對象被顯式銷毀時執行。
function __destruct() {}
6 final 關鍵字
PHP 5 新增了一個 final 關鍵字。如果父類中的方法被聲明為final,則子類無法覆蓋該方法; 如果一個類被聲明為final,則不能被繼承。
7 繼承和構造函數
父類
子類
結果
有構造函數
無構造函數
父構造
有構造函數
有構造函數
子構造
8 接口
可以通過interface來定義一個接口,就像定義一個標准的類一樣。
注意:
1)但其中定義所有的方法都是空的;
2)接口中定義的所有方法都必須是public,這是接口的特性;
3)實現多個接口時,接口中的方法不能有重名;
4)接口也可以繼承,通過使用extends操作符;
5)接口中也可以定義常量。接口常量和類常量的使用完全相同。 它們都是定值,不能被子類或子接口修改。
復制代碼 代碼如下:// 聲明一個'iTemplate'接口
interface iTemplate
{
public function setVariable($name, $var);
public function getHtml($template);
}
// 實現接口
// 下面的寫法是正確的
class Template implements iTemplate
{
private $vars = array();
public function setVariable($name, $var)
{
$this->vars[$name] = $var;
}
public function getHtml($template)
{
foreach($this->vars as $name => $value) {
$template = str_replace('{' . $name . '}', $value, $template);
}
return $template;
}
}
9 屬性
類的變量成員叫做“屬性”,屬性聲明是由關鍵字public或者protected或者private開頭,然後跟一個變量來組成。 屬性中的變量可以初始化,但是初始化的值必須是常數,這裡的常數是指php腳本在編譯階段時就為常數,而不是在編譯階段之後在運行階段運算出的常數。
在PHP5 中,預定義了兩個函數“__get()”和“__set()”來獲
取和賦值其屬性,以及檢查屬性的“__isset()”和刪除屬性的方法“__unset()”。
簡單的說一個是取值,一個是賦值。,“__set()”和“__get()”這兩個方法,這兩個方法不是默認存在的,而是我們手工添加到類裡面去的,像構造方法(__construct())一樣, 類裡面添加了才會存在,可以按下面的方式來添加這兩個方法,當然也可以按個人的風格來添加://__get()方法用來獲取私有屬性
復制代碼 代碼如下:<?php
class Person{
//下面是人的成員屬性
private $name; //人的名字
private $sex; //人的性別
private $age; //人的年齡
//__get()方法用來獲取私有屬性
private function __get($property_name){
if(isset($this->$property_name)){
return($this->$property_name);}else {
return(NULL);
}
}
}
//__set()方法用來設置私有屬性
private function __set($property_name, $value){
$this->$property_name = $value;
}
//__isset()方法
private function __isset($nm){
echo "isset()函數測定私有成員時,自動調用<br>";
return isset($this->$nm);
}
//__unset()方法
private function __unset($nm){
echo "當在類外部使用unset()函數來刪除私有成員時自動調用的<br>";
unset($this->$nm);
}
}
$p1=new Person();
$p1->name="this is a person name";
//在使用isset()函數測定私有成員時,自動調用__isset()方法幫我們完成,返回結果為true
echo var_dump(isset($p1->name))."<br>";
echo $p1->name."<br>";
//在使用unset()函數刪除私有成員時,自動調用__unset()方法幫我們完成,刪除name私有屬性
unset($p1->name);
//已經被刪除了, 所這行不會有輸出
echo $p1->name;
?>
復制代碼 代碼如下:<?php
class Person{
//下面是人的成員屬性
private $name;
//人的名字
private $sex;
//人的性別
private $age;
//人的年齡
//__get()方法用來獲取私有屬性
private function __get($property_name){
if(isset($this->$property_name)){
return($this->$property_name);
}else{
return(NULL);
}
}
}
//__set()方法用來設置私有屬性
private function __set($property_name, $value){
$this->$property_name = $value;
}
//__isset()方法
private function __isset($nm){
echo "isset()函數測定私有成員時,自動調用<br>";
return isset($this->$nm);
}
//__unset()方法
private function __unset($nm){
echo "當在類外部使用unset()函數來刪除私有成員時自動調用的<br>";
unset($this->$nm);
}
}
$p1=new Person();
$p1->name="this is a person name";
//在使用isset()函數測定私有成員時,自動調用__isset()方法幫我們完成,返回結果為true
echo var_dump(isset($p1->name))."<br>";
echo $p1->name."<br>";
//在使用unset()函數刪除私有成員時,自動調用__unset()方法幫我們完成,刪除name私有屬性
unset($p1->name);
//已經被刪除了, 所這行不會有輸出
echo $p1->name;
?>
10 克隆
對象復制可以通過clone關鍵字來完成(如果對象中存在__clone()方法,會先被調用)。對象中的 __clone()方法不能直接調用。
當對象被復制後,PHP5會對對象的所有屬性執行一個“淺復制”(shallow copy)。所有的屬性中的引用 仍然不變,指向原來的變量。如果定義了__clone()方法,則新創建的對象(復制生成的對象)中的__clone()方法會被調用, 可用於修改屬性的值(如果有必要的話)。
希望本文所述對大家的php面向對象程序設計有所幫助。