當前位置:首頁 » 編程語言 » phpthis繼承

phpthis繼承

發布時間: 2022-07-01 15:28:45

php 繼承父類 怎麼調用父類的方法

直接

$this->parent_function($parameter)

或者

parent::parent_function($parameter)

❷ PHP繼承機制和JS的繼承機制有什麼不同

類式繼承就像java的繼承一樣,思想也比較簡單:在子類型構造函數的內部調用超類型構造函數。

原型式繼承是藉助已有的對象創建新的對象,將子類的原型指向父類,就相當於加入了父類這條原型鏈

而你的 下面這段代碼不是嚴格意義上的類式繼承,按照Nicholas C.Zakas的說法,這個應該叫做組合式繼承。它調用了兩次parent2()。第一次是 child2.prototype=new parent2('param'); child2就會得到兩個屬性param,getParam(),他們都是parent2的屬性,但是他們在child2的原型中。第二次是parent2.call(this,cparam); 這次又在新對象上創建了實例屬性param,getParam()。於是,這兩個屬性就屏蔽了原型中的兩個同名屬性。這有什麼好處呢,就是你在構建一個child3時也繼承parent2()的屬性,還可以定義自己的屬性。與此同時他長的就和他兄弟不同了,但又有一樣的「血統(使用父類的方法)」。

❸ php中的類是單繼承,那要有多個類繼承怎麼辦

PHP沒有多繼承的特性。即使是一門支持多繼承的編程語言,我們也很少會使用這個特性。在大多數人看來,多繼承不是一種好的設計方法。想要給某個類添加額外的特性,不一定要使用繼承。這里我提供一種模擬多繼承的方法以供參考。


PHP有一個魔術方法,叫做__call。當你調用一個不存在的方法時,這個方法會被自動調用。這時,我們就有機會將調用重定向到一個存在的方法。繼承多個父類的子類,尋找方法的過程一般是這樣的:

本身的方法 -> 父類1的方法 -> 父類2的方法...


模擬過程大致是這樣:將各個父類實例化,然後作為子類的屬性。這些父類提供一些公有的方法。當子類擁有某方法時,__call()函數不會被調用。這相當於「覆蓋」了父類的方法。當調用了不存在的方法時,通過__call()方法依次從父類中尋找可以調用的方法。雖然這不是完備的多繼承,但可以幫助我們解決問題。


<?php
classParent1{
functionmethod1(){}
functionmethod2(){}
}
classParent2{
functionmethod3(){}
functionmethod4(){}
}
classChild{
protected$_parents=array();
publicfunctionChild(array$parents=array()){
$_parents=$parents;
}

publicfunction__call($method,$args){
//從「父類"中查找方法
foreach($this->_parentsas$p){
if(is_callable(array($p,$method))){
returncall_user_func_array(array($p,$method),$args);
}
}
//恢復默認的行為,會引發一個方法不存在的致命錯誤
returncall_user_func_array(array($this,$method),$args);
}
}
$obj=newChild(array(newParent1(),newParent2()));
$obj->method1();
$obj->method3();

這里沒有涉及屬性的繼承,但實現起來並不困難。可以通過__set()和__get()魔術方法來模擬屬性的繼承。請你動手實踐。

❹ php私有方法不能被繼承為什麼還能輸出難道$this能代表父類

這是面向對象的特性,解釋如下:

  1. 類B繼承了類A,類B就具有了類A的一切屬性和方法。

  2. 類A的bb方法自然會被類B繼承,繼承後類B也擁有了與類A一樣的bb方法。

  3. 類A的cc方法,雖然是private的,但是類B並沒有直接調用,而是通過其繼承自類A的bb方法調用,是合法的。

$this還是當前類對象,不是父類對象。之所以類B的bb方法中通過$this調用cc方法合法,是因為bb方法是類B繼承自類A得到的,而bb方法調用cc方法是類內調用,不是類間調用,不受訪問控制約束限制。

❺ php 面向對象 繼承 問題

這個應該這樣解釋吧,Bar裡面的testPublic() :這個是公有的,而testPrivate() :這個是私有的,下面的Foo頁是一樣,但是Foo裡面的testPublic() 把父類的testPublic() 覆蓋掉了,所以,在執行時候,testPublic() 就會執行子類的,而testPrivate() 這個父類裡面是私有的不能被子類覆蓋所以還是調用父類裡面的

❻ php子類繼承父類內存空間問題

要明白,類跟對象實例是不一樣的。a類和b類是php聲明的類,實例化之前並不佔額外空間。當實例化成$a和$b後,這兩個實例化的對象的內部屬性是不相關的。就像兩個不同模型的車一樣,模型的樣子是繼承的,但實際出廠的每輛車都是不一樣的。
其實即使是統一模型做出來的車也是單獨的個體。比如說
$a = new a;
$b = new a;
$a和$b也是完全不相關的兩個對象實例,內部的屬性也是不一樣的。
所以當進行賦值$b->a = 13;只是改變了$b的成員a的值,對$a的成員a是沒有任何影響的。
請採納,謝謝!

❼ php類繼承派生

還是哪個問題,這是類的規則,私有屬性和方法只有它的當前類中使用,之外的類包括它的父類和子類都不能訪問。建議你看看php手冊,裡面有詳細說明,下面是復制有關私有方法和屬性的說明:

訪問控制
對屬性或方法的訪問控制,是通過在前面添加關鍵字 public、protected 或 private 來實現的。由 public 所定義的類成員可以在任何地方被訪問;由 protected 所定義的類成員則可以被其所在類的子類和父類訪問(當然,該成員所在的類也可以訪問);而由 private 定義的類成員則只能被其所在類訪問。

❽ php類繼承,方法不能繼承

你的$name是私有的,無法繼承,要protected才能繼承

❾ PHP私有屬性繼承問題

你設置了 private $Pname; 為私有變數 就導致了你的派生類是無法訪問父類的成員可以使用 protected $Pname 這樣就可以使得派生類和基類都能范圍該類的成員。 ===你初始化$student=new Student('1','zhangsan','18','男','9月23');後 不用重載parent::IT(); 這樣只能echo出父類的那句話。。你要的是覆蓋的效果 所以直接echo "$this->Pname 的工作是學生<br>"; 就可以了

❿ PHP繼承的問題,調用父類的方法this指向問題。

我來說一說:


【一】…………public(僅有)屬性和方法的繼承…………

classa{
public$var='vara<br/>';
publicfunctionm(){
echo'funa<br/>';
}
publicfunctionrun(){
echo$this->var;
$this->m();
}
}

classbextendsa{
public$var='varb<br/>';
publicfunctionm(){
echo'funb<br/>';
}
}
$li=newb();
$li->run();
echo'<hr>';
var_mp($li);

輸出:

varb
funb
————————————————————————————
object(b)[1]
public'var'=>string'varb<br/>'(length=11)

在這段代碼中所表示的,是我們常見的一種繼承方式,同為公有屬性的$var 和公有方法m()


在這里,$var和m()都被繼承並覆寫,實例化過後,內存中只有一個$var實例,通過var_mp($li);我們可以看到它。



【二】…………private(私有)屬性和方法的繼承…………

classa{
private$var='vara<br/>';
privatefunctionm(){
echo'funa<br/>';
}
publicfunctionrun(){
echo$this->var;
$this->m();
var_mp($this);
echo'<br/><br/>';
}
}

classbextendsa{
private$var='varb<br/>';
privatefunctionm(){
echo'funb<br/>';
}
publicfunctionrun(){
echo$this->var;
$this->m();
var_mp($this);
echo'<br/><br/>';
parent::run();
}
}
$li=newb();
$li->run();
echo'<hr>';
var_mp($li);

輸出:

varb
funb
object(b)[1]
private'var'=>string'varb<br/>'(length=11)
private'var'(a)=>string'vara<br/>'(length=11)
.
.
vara
funa
object(b)[1]
private'var'=>string'varb<br/>'(length=11)
private'var'(a)=>string'vara<br/>'(length=11)
.
————————————————————————————————
object(b)[1]
private'var'=>string'varb<br/>'(length=11)
private'var'(a)=>string'vara<br/>'(length=11)

這個時候,我們可以看到,在調用run方法時,首先它會調用到b類的私有屬性$var 和私有方法m(),隨後,又使用parent::run()調用父類的run()方法,我們可以看到,父類的run()方法調用後,它所調用的屬性和方法,都是a類的兩個私有屬性和方法,這種形式,和你的問題一致;


而它與$this指向無關,我們可以在這里看到,兩個$this都是指向b類。


而最有意思的是,在$li句柄中,我們卻看到了兩個屬性!一個是b類的屬性,一個是a類的屬性,這兩個屬性同時存在著,那麼,私有方法也自然是同時存在著。


【三】…………私有屬性和方法能不能被繼承…………

classa{
private$var='vara<br/>';
privatefunctionm(){
echo'funa<br/>';
}
}
classbextendsa{
publicfunctionrun(){
echo$this->var;
$this->m();
}
}
$li=newb();
$li->run();

輸出:

Notice:Undefinedproperty:b::$varinE:...onLine9
Fatalerror:Calltoprivatemethoda::m()fromcontext'b'inE:...onLine10

這可以證明,私有屬性和方法,無法被繼承,所以,你的代碼示例中所說,將a類的m()方法更改為private後,會顯示aa的屬性,也就可以理解明白了。

熱點內容
javaip埠 發布:2025-02-04 09:27:09 瀏覽:853
國產存儲科技進步二等獎 發布:2025-02-04 09:13:00 瀏覽:693
編程課v 發布:2025-02-04 08:45:00 瀏覽:106
模擬器能有手機腳本么 發布:2025-02-04 08:39:50 瀏覽:757
android顯示html圖片 發布:2025-02-04 08:35:31 瀏覽:791
如何查學信網賬號及密碼 發布:2025-02-04 08:33:55 瀏覽:502
linux32位jdk 發布:2025-02-04 08:33:55 瀏覽:247
康佳伺服器連接失敗是怎麼回事 發布:2025-02-04 08:18:51 瀏覽:916
編譯編譯有什麼 發布:2025-02-04 08:05:52 瀏覽:735
讓外網訪問內網伺服器 發布:2025-02-04 08:02:20 瀏覽:783