>php教程 >PHP开发 >PHP 객체 지향 메소드 오버로딩의 두 가지 버전 비교

PHP 객체 지향 메소드 오버로딩의 두 가지 버전 비교

黄舟
黄舟원래의
2016-12-14 11:57:211134검색

여러 함수가 동일한 이름을 사용하지만, 매개변수 목록, 즉 매개변수의 개수나 (및) 데이터 유형이 다를 수 있습니다. 호출 시 메서드 이름은 동일하더라도 해당 함수가 자동으로 생성될 수 있습니다. 매개변수 목록에 따라 호출됩니다.
PHP4는 몇 가지 간단한 객체 지향 기능만 구현하는 반면, PHP5의 객체 지원은 앞으로 훨씬 더 강력해질 것입니다.
다형성 구현의 경우 PHP4는 재정의만 지원하고 오버로드는 지원하지 않습니다. 그러나 우리는 오버로딩 구현을 "시뮬레이트"하기 위해 몇 가지 트릭을 사용할 수 있습니다.
PHP5는 덮어쓰기와 오버로딩을 지원할 수 있지만 오버로딩의 구체적인 구현은 여전히 ​​다른 언어와 상당히 다릅니다.
1. PHP4의 "시뮬레이트" 오버로딩

다음 코드를 시도해 보세요:

//매개변수 수에 따라 다른 메서드를 실행하도록 선택합니다( PHP4 "오버로딩"(다형성의 일종)

class Myclass
{
function Myclass()
{
$method = "method"
$this->$method();
}

함수 메소드1($x)
{
echo "method1"; method2($x, $y)
{

echo 'method2';

}
}

//클래스에서 추가 처리를 통해 이 클래스를 사용합니다. 사용자에게 투명합니다.
$obj1 = new Myclass('A'); //method1이 호출됩니다.

$obj2 = new Myclass('B','C') //method2가 호출됩니다.

?> 🎜>
위 코드에서는 생성자에서 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

$this->attriable; = $this->one

}

함수 1($one, $two)
{
$this->one=$one

$this- >two=$two;

$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는 이러한 메서드를 호출합니다.

다음 예에서 __get 및 __set는 속성 변수 배열에 대한 모든 액세스를 대체합니다. 필요한 경우 원하는 모든 유형의 필터링을 구현할 수도 있습니다. 예를 들어 스크립트는 속성 값 설정을 비활성화하거나 특정 접두사로 시작하거나 특정 유형의 값을 포함할 수 있습니다. __call 메서드는 정의되지 않은 메서드를 호출하는 방법을 보여줍니다. 정의되지 않은 메서드를 호출하면 메서드 이름과 해당 메서드에서 받은 매개변수가 __call 메서드에 전달되고, PHP는 정의되지 않은 메서드에 __call 값을 반환합니다.


코드는 다음과 같습니다:

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]);
}
}

public function displayObject($p)

{
echo ("전달한 내용은 객체인 경우 내용은 다음과 같습니다:
");
print_r($p);
echo "


";
}

공용 함수 displayArray( $p)

{
echo ("전달한 내용은 다음 내용의 배열입니다:
")
print_r($p)
echo "


";
}

public function displayScalar($p)

{
echo ("전달한 내용은 다음 내용을 포함하는 별도의 변수입니다:
" . $p );
echo "
}
}

$o = new Overloader();

//__set()을 호출하여 존재하지 않는 속성 변수

$o->dynaProp = "Dynamic Content";

//Call __get()

print($o->dynaProp . "< br>n");

//__call() 호출

//$o->dynaMethod("Leon", "Zeev");

$o-> display(array(1,2, 3));

$o->display('Cat');
?>

위 코드에서 display() 메소드는 이는 매개변수의 유형과 개수에 따라 결정될 수 있습니다. 클래스에서 해당 코드 세그먼트를 호출하여 개체 메서드의 오버로드를 실현합니다.

읽어주셔서 감사합니다. 더 많은 관련 내용을 원하시면 PHP 중국어 홈페이지(www.php.cn)를 주목해주세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.