函數重載php
⑴ php為什麼不支持函數重載啊
php 作為一種弱類型語言,本身不能像強類型如java ,c++那樣,直接的實現重載。不過可以通過一些方法,間接的實現重載。
使用一個統一的函數來實現重載。該方法要使用func_get_args()和func_num_args()方法。
<?php
function test1($name){
echo $name;
}
function test2($name,$age){
echo $name.$age;
}
function load(){
//返回輸入的元素數目
$num=func_num_args();
//返回輸入元素列表的數組形式
$arr=func_get_args();
if($num==1){
test1($arr[0]);
}else {
test2($arr[0],$arr[1]);
}
}
load("a");
echo "<br/>";
load("a","b");
?>
2.當對象試著調用不存在或者受許可權限制的方法時,__call()方法會被自動調用,從而可以實現類型重載的效果。該方法是php5新增的方法。
<?php
class A{
//name :調用的方法名字。args:參數列表
function __call($name,$args){
$num=count($args);
if($num==1){
$this->test1($args[0]);
}
else {
$this->test2($args[0],$args[1]);
}
}
function test1($name){
echo $name;
}
function test2($name, $age){
echo $name." ".$age;
}
}
$a=new A();
$a->a("a");
echo "<br/>";
$a->a("a","b");
?>
⑵ php怎麼方法重載
php面向對象(OOP)編程完全教程:12.重載新的方法
在學習PHP 這種語言中你會發現, PHP中的方法是不能重載的, 所謂的方法重載就是定義相同的方法名,通過「參數的個數「不同或「參數的類型「不同,來訪問我們的相同方法名的不同方法。但是因為PHP是弱類型的語言, 所以在方法的參數中本身就可以接收不同類型的數據,又因為PHP的方法可以接收不定個數的參數,所以通過傳遞不同個數的參數調用不相同方法名的不同方法也是不成立的。所以在PHP裡面沒有方法重載。不能重載也就是在你的項目中不能定義相同方法名的方法。另外,因為PHP沒有名子空間的概念,在同一個頁面和被包含的頁面中不能定義相同名稱的方法, 也不能定義和PHP給我提供的方法的方法重名,當然在同一個類中也不能定義相同名稱的方法。
我們這里所指的重載新的方法所指的是什麼呢?其實我們所說的重載新的方法就是子類覆蓋父類的已有的方法,那為什麼要這么做呢?父類的方法不是可以繼承過來直接用嗎?但有一些情況是我們必須要覆蓋的,比如說我們前面提到過的例子裡面, 「Person」這個人類裡面有一個「說話」的方法,所有繼承「Person」類的子類都是可以「說話」的, 我們「Student」類就是「Person」類的子類,所以「Student」的實例就可以「說話「了, 但是人類裡面「說話」的方法裡面說出的是「Person」類裡面的屬性, 而「Student」類對「Person」類進行了擴展,又擴展出了幾個新的屬性,如果使用繼承過來的「say()」說話方法的話,只能說出從「Person」類繼承過來的那些屬性,那麼新擴展的那些屬性使用這個繼承過來的「say()」的方法就說不出來了,那有的人就問了,我在「Student」這個子類中再定義一個新的方法用於說話,說出子類裡面所有的屬性不就行了嗎?一定不要這么做, 從抽象的角度來講, 一個「學生」不能有兩種「說話」的方法,就算你定義了兩個不同的說話的方法,可以實現你想要的功能,被繼承過來的那個「說話「方法可能沒有機會用到了,而且是繼承過來的你也刪不掉。這個時候我們就要用到覆蓋了。
雖然說在PHP裡面不能定義同名的方法, 但是在父子關系的兩個類中,我們可以在子類中定義和父類同名的方法,這樣就把父類中繼承過來的方法覆蓋掉了。
代碼
<?
//定義一個"人"類做為父類
class Person
{
//下面是人的成員屬性
var $name; //人的名子
var $sex; //人的性別
var $age; //人的年齡
//定義一個構造方法參數為屬性姓名$name、性別$sex和年齡$age進行賦值
function __construct($name, $sex, $age)
{
$this->name=$name;
$this->sex=$sex;
$this->age=$age;
}
//這個人可以說話的方法, 說出自己的屬性
function say()
{
echo "我的名子叫:".$this->name." 性別:".$this->sex." 我的年齡是:".$this->age;
}
}
class Student extends Person
{
var $school; //學生所在學校的屬性
//這個學生學習的方法
function study()
{
echo "我的名子叫:".$this->name." 我正在".$this->school." 學習";
}
//這個學性可以說話的方法, 說出自己所有的屬性,覆蓋了父類的同名方法
function say()
{
echo "我的名子叫:".$this->name." 性別:".$this->sex." 我的年齡是:".$this->age."我在".$this->school."上學;
}
}
?>
上面的例子, 我們就在「Student」子類里覆蓋了繼承父類裡面的」say()」的方法,通過覆蓋我們就實現了對「方法」擴展。
但是,像這樣做雖然解決了我們上面說的問題,但是在實際開發中,一個方法不可能就一條代碼或是幾條代碼,比如說「Person」類裡面的「say()」方法有裡面有100條代碼,如果我們想對這個方法覆蓋保留原有的功能外加上一點點功能,就要把原有的100條代碼重寫一次, 再加上擴展的幾條代碼,這還算是好的,而有的情況,父類中的方法是看不見原代碼的,這個時候你怎麼去重寫原有的代碼呢?我們也有解決的辦法,就是在子類這個方法中可以調用到父類中被覆蓋的方法, 也就是把被覆蓋的方法原有的功能拿過來再加上自己的一點功能,可以通過兩種方法實現在子類的方法中調用父類被覆蓋的方法:
一種是使用父類的「類名::「來調用父類中被覆蓋的方法;
一種是使用「parent::」的方試來調用父類中被覆蓋的方法;
代碼
class Student extends Person
{
var $school; //學生所在學校的屬性
//這個學生學習的方法
function study()
{
echo "我的名子叫:".$this->name." 我正在".$this->school." 學習";
}
//這個學性可以說話的方法, 說出自己所有的屬性,覆蓋了父類的同名方法
function say()
{
//使用父類的"類名::"來調用父類中被覆蓋的方法;
// Person::say();
//或者使用"parent::"的方試來調用父類中被覆蓋的方法;
parent::say();
//加上一點自己的功能
echo "我的年齡是:".$this->age."我在".$this->school."上學.";
}
}
現在用兩種方式都可以訪問到父類中被覆蓋的方法,我們選那種方式最好呢?用戶可能會發現自己寫的代碼訪問了父類的變數和函數。如果子類非常精煉或者父類非常專業化的時候尤其是這樣。 不要用代碼中父類文字上的名字,應該用特殊的名字 parent,它指的就是子類在 extends 聲明中所指的父類的名字。這樣做可以避免在多個地方使用父類的名字。如果繼承樹在實現的過程中要修改,只要簡單地修改類中 extends 聲明的部分。
同樣,構造方法在子類中如果沒有聲明的話,也可以使用父類中的構造方法,如果子類中重新定義了一個構造方法也會覆蓋掉父類中的構造方法,如果想使用新的構造方法為所有屬性賦值也可以用同樣的方式。
代碼
class Student extends Person
{
var $school; //學生所在學校的屬性
function __construct($name, $sex, $age, $school)
{
//使用父類中的方法為原有的屬性賦值
parent::__construct($name, $sex, $age);
$this->school=$school;
}
//這個學生學習的方法
function study()
{
echo "我的名子叫:".$this->name." 我正在".$this->school." 學習";
}
//這個人可以說話的方法, 說出自己的屬性
function say()
{
parent::say();
//加上一點自己的功能
echo "我的年齡是:".$this->age."我在".$this->school."上學.";
}
}
⑶ php默認構造函數 重載操作 析構函數的差別
構造是new
一個類的時候的,初始化調用的,通常命名為類名或者__construct
php裡面因為無類型,所有沒有
重載,只能模擬重載
析構在類釋放的時候調用,不常用
⑷ php中如何實現函數重載呢
PHP本身不能函數重載的,不過你可以使用類中的__call的魔術方法來實現。該魔術方法接受兩個參數,一個數方法的名稱,一個是包含該方法參數的數組。當對一個類調用一個不可見的方法時(比如該方法是private或者根本沒有這個方法)被觸發調用。
⑸ PHP重載 有什麼用
用到的情況還是很多的 比方說 你在做底層開發時 經常會創建一些共有的 變數 就要載入這些數據 這是就得用這些函數了
⑹ PHP中 重載函數 __get() __set() _call作用及參數是什麼
void __set ( string $name , mixed $value )
__set在對類內不可訪問的成員賦值時被調用,$name是成員名,$value是賦的值
mixed __get ( string $name )
__get在對內類內不可訪問的成員取值時被調用,$name是成員名
mixed __call ( string $name , array $arguments )
__call在對類內不可訪問的方法調用時被調用,$name是方法名,$arguments是調用這個方法提供的參數
⑺ php函數的簡介
用戶自定義函數一個函數可由以下的語法來定義: <?phpfunction foo($arg_1, $arg_2, ..., $arg_n){ echo "Example function./n"; return $retval;}?>任何有效的 php 代碼都有可能出現在函數內部,甚至包括其它函數和類定義。
在 php 3 中,函數必須在被調用之前定義。而 php 4 則不再有這樣的條件。除非函數如以下兩個範例中有條件的定義。
如果一個函數以以下兩個範例的方式有條件的定義,其定義必須在調用之前完成。 <?phpfunction foo(){ function bar() { echo "I don't exist until foo() is called./n"; }}/* We can't call bar() yet since it doesn't exist. */foo();/* Now we can call bar(), foo()'s processesing has made it accessable. */bar();?>php 中的所有函數和類都具有全局域,可以在內部定義外部調用,反之亦然。
php 不支持函數重載,也不可能取消定義或者重定義已聲明的函數。
注:函數名是非大小寫敏感的,不過在調用函數的時候,通常使用其在定義時相同的形式。
php 3 雖然支持默認參數(更多信息請參照默認參數的值),但是卻不支持可變的參數個數。php 4 支持:見可變長度的參數列表和涉及到的相關函數func_num_args(),func_get_arg(),以及func_get_args()以獲取更多的信息。
在 php 中可以調用遞歸函數。但是要避免遞歸函數/方法調用超過 100-200 層,因為可能會破壞堆棧從而使當前腳本終止。 sys_getloadavt()可以獲得系統負載情況。該函數返回一個包含三個元素的數組,每個元素分別代表系統再過去的1、5和15分鍾內的平均負載。
與其讓伺服器因負載過高而宕掉,不如在系統負載很高時主動die掉一個腳本,sys_getloadavg()就是用來幫你實現這個功能的。不過很遺憾,該函數在windows下無效。 在發送頁面前先看看用戶的瀏覽器都能做些什麼是不是挺好?get_browser()能獲得用戶的瀏覽器類型,以及瀏覽器支持的功能,不過首先你需要一個php_browscap.ini文件,用來給函數做參考文件。
要注意,該函數對瀏覽器功能的判斷是基於該類瀏覽器的一般特性的。例如,如果用戶關閉了瀏覽器對JavaScript的支持,函數無法得知這一點。但是在判斷瀏覽器類型和OS平台方面,該函數還是很准確的。 glob()會讓你覺得用opendir(), readdir()和closedir()來尋找文件非常蠢。
⑻ php 到底可不可以重載
php 作為一種弱類型語言,本身不能像強類型如java ,c++那樣,直接的實現重載。不過可以通過一些方法,間接的實現重載。
使用一個統一的函數來實現重載。該方法要使用func_get_args()和func_num_args()方法。
<?php
functiontest1($name){
echo$name;
}
functiontest2($name,$age){
echo$name.$age;
}
functionload(){
//返回輸入的元素數目
$num=func_num_args();
//返回輸入元素列表的數組形式
$arr=func_get_args();
if($num==1){
test1($arr[0]);
}else{
test2($arr[0],$arr[1]);
}
}
load("a");
echo"<br/>";
load("a","b");
?>
2.當對象試著調用不存在或者受許可權限制的方法時,__call()方法會被自動調用,從而可以實現類型重載的效果。該方法是php5新增的方法。
<?php
classA{
//name:調用的方法名字。args:參數列表
function__call($name,$args){
$num=count($args);
if($num==1){
$this->test1($args[0]);
}
else{
$this->test2($args[0],$args[1]);
}
}
functiontest1($name){
echo$name;
}
functiontest2($name,$age){
echo$name."".$age;
}
}
$a=newA();
$a->a("a");
echo"<br/>";
$a->a("a","b");
?>