여러 함수가 동일한 이름을 사용하지만, 매개변수 목록, 즉 매개변수의 개수나 (및) 데이터 유형이 다를 수 있습니다. 호출 시 메서드 이름은 동일하더라도 해당 함수가 자동으로 생성될 수 있습니다. 매개변수 목록에 따라 호출됩니다.
PHP4는 몇 가지 간단한 객체 지향 기능만 구현하는 반면, PHP5의 객체 지원은 앞으로 훨씬 더 강력해질 것입니다.
다형성 구현의 경우 PHP4는 재정의만 지원하고 오버로드는 지원하지 않습니다. 그러나 우리는 오버로딩 구현을 "시뮬레이트"하기 위해 몇 가지 트릭을 사용할 수 있습니다.
PHP5는 덮어쓰기와 오버로딩을 지원할 수 있지만 오버로딩의 구체적인 구현은 여전히 다른 언어와 상당히 다릅니다.
1. PHP4의 "시뮬레이트" 오버로딩
다음 코드를 시도해 보세요:
//매개변수 수에 따라 다른 메서드를 실행하도록 선택합니다( PHP4 "오버로딩"(다형성의 일종)
class Myclass
{
function Myclass()
{
$method = "method"
$this->$method();
}
함수 메소드1($x)
{
echo "method1"; method2($x, $y)
{
}
}
//클래스에서 추가 처리를 통해 이 클래스를 사용합니다. 사용자에게 투명합니다.
$obj1 = new Myclass('A'); //method1이 호출됩니다.
?> 🎜>
위 코드에서는 생성자에서 func_num_args() 함수를 사용하여 매개변수 개수를 가져오면 자동으로 method1 또는 method2 메서드를 실행할 수 있습니다. func_get_arg(i) 및 func_get_args() 함수를 결합할 수 있습니다. . 위의 예를 개선하세요
2, PHP5에서 오버로딩을 사용하세요
먼저 다음 예를 보세요:
다음과 같이 코드를 복사하세요:< ?php
class Myclass{
public $attriable;
public $one = "이것은 하나입니다";
public $two = "이것은 2개입니다";
function __construct()
{
}
function one($one)
{
$this->one=$one
}
함수 1($one, $two)
{
$this->one=$one
$this->attriable = $this->one . $this->two
}
함수 표시()
{
echo $this->attriable;
$one = "이건 내 수업이야"
$two = "내가 최고야"; myclass = new myclass();
$myclass->one($one);
$myclass->display();
$myclass->one($one, $ two);
$myclass->display();
//이 예제의 접근 방식은 PHP에서 올바르지 않습니다!
?>
C++, Java, C# 오버로딩을 사용해 본 사람들은 위의 오버로딩 구현을 위한 PHP 코드 작성에 익숙할 것입니다. 그러나 이것은 PHP5에서는 사실이 아닙니다. PHP5는 앞서 언급한 언어를 모방한 것이 아니지만 메소드 오버로딩을 구현하기 위한 고유한 메소드 세트를 가지고 있습니다(좋은지 나쁜지는 여기서 논의하지 않습니다). PHP5의 클래스는 PHP4의 클래스보다 훨씬 강력하지만 "오버로딩" 문제는 예상한 대로 "개선"되지 않았습니다. "오버로딩"은 C++, Java, C# 등과 같은 "강력한" 유형의 언어에서 다양한 매개변수 유형을 통해 달성될 수 있습니다. "고정 매개변수"가 전달되는 언어에서는 Java처럼 매개변수의 개수만큼 전달될 수도 있지만, PHP는 약한 유형의 언어이므로 위와 같은 "오버로딩"은 발생하지 않습니다.
PHP5의 오버로드는 __get, __set 및 __call과 같은 몇 가지 특수 메서드를 통해 수행될 수 있습니다. Zend 엔진이 멤버에 액세스하려고 시도했지만 찾을 수 없을 때 PHP는 이러한 메서드를 호출합니다.
class Overloader
{
private $properties = array();
function __get ($property_name )
{
if(isset($this->properties[$property_name]))
{
return($this->properties[$property_name])
else
{
return(NULL);
}
}
function __set($property_name, $value)
{
$this -> 속성[$property_name] = $값
}
공용 함수 __call($method, $p)
{
print("$method()
n 호출")
//print("인수: "); 🎜>//print_r($args);
if($method == 'display')
{
if(is_object($p[0]))
$this->displayObject ($p[0]);
else
if(is_array($p[0]))
$this->displayArray($p[0])
else
$this->displayScalar($p[0]);
}
}
{
echo ("전달한 내용은 객체인 경우 내용은 다음과 같습니다:
");
print_r($p);
echo "
{
echo ("전달한 내용은 다음 내용의 배열입니다:
")
print_r($p)
echo "
{
echo ("전달한 내용은 다음 내용을 포함하는 별도의 변수입니다:
" . $p );
echo "
}
}
$o->dynaProp = "Dynamic Content";
print($o->dynaProp . "< br>n");
//$o->dynaMethod("Leon", "Zeev");
$o->display('Cat');
?>