>백엔드 개발 >PHP 튜토리얼 >PHP의 오버로딩 및 매직 메소드 예제에 대한 자세한 설명

PHP의 오버로딩 및 매직 메소드 예제에 대한 자세한 설명

黄舟
黄舟원래의
2017-11-02 09:16:101285검색

Definition: PHP는 (두 개의 밑줄)로 시작하는 모든 클래스 메소드를 매직 메소드로 예약합니다. 따라서 클래스 메소드를 정의할 때 위의 매직 메소드를 제외하고는 접두사로 를 붙이지 않는 것이 좋습니다.

Function: 패턴 메소드를 사용하여 PHP 객체 지향오버로딩을 쉽게 구현할 수 있습니다(오버로딩은 클래스속성 및 메소드를 동적으로 생성하는 것을 의미합니다)

사실 많은 블로거가 이미 이러한 메소드를 작성했지만,,,, 다시 말하겠습니다. . 누가 와서 들어달라고 했나요? 떠나기 전에 그렇게 많은 단어를 다 읽는 것은 쉽지 않습니다!

1.construct, destruct
constuct는 객체를 생성할 때 호출됩니다.
destruct는 객체가 명시적으로 삭제되거나 스크립트가 끝날 때 호출됩니다.

class Foo {    
private $name;    
private $link;    
public function construct($name) {        
$this->name = $name;
    }    
    public function destruct() {        
    echo 'Destroying: ', $this->name, PHP_EOL;//PHP_EOL代表php的换行符    }
}

중지, 오버로딩의 정의와 사용부터 시작하겠습니다.

정의

: PHP에서 제공하는 "overloading"(오버로딩)은 클래스 속성과 메서드를 동적으로 "생성"하는 것을 의미합니다. (우리는 매직 메소드를 통해 이를 달성합니다.)

Function

: 현재 환경에서 정의되지 않았거나 보이지 않는 클래스 속성이나 메소드가 호출되면 오버로드된 메소드가 호출됩니다. 이러한 정의되지 않거나 보이지 않는 클래스 속성이나 메서드를 참조하기 위해 나중에 "액세스할 수 없는 속성" 및 "액세스할 수 없는 메서드"를 사용할 것입니다.

참고

: 오버로드된 모든 메서드는 public으로 선언되어야 합니다.

2.get, set, isset, unset, call, callStatic //왜 같이 묶였나요?

set은 액세스할 수 없거나 존재하지 않는 속성에 값을 할당할 때 호출됩니다.

get은 액세스할 수 없거나 존재하지 않는 속성을 읽을 때 호출됩니다.

isset은 액세스할 수 없는 속성에 대해 isset() 또는 empty()를 호출할 때 호출됩니다. 또는 존재하지 않는 속성 호출됨

unset 액세스할 수 없거나 존재하지 않는 속성을 설정 해제할 때 호출됨


call 메서드가 액세스할 수 없거나 존재하지 않는 메서드로 호출될 때 호출됨

callStatic 정적 메서드가 액세스할 수 없거나 존재하지 않는 메서드로 호출될 때 호출됨


예제 #1 속성 오버로딩을 위해 get(), set(), isset() 및 unset() 사용

<?php
class PropertyTest {
     /**  被重载的数据保存在此  */
    private $data = array();

 
     /**  重载不能被用在已经定义的属性  */
    public $declared = 1;

     /**  只有从类外部访问这个属性时,重载才会发生 */
    private $hidden = 2;

    public function set($name, $value) 
    {
        echo "Setting &#39;$name&#39; to &#39;$value&#39;\n";
        $this->data[$name] = $value;
    }


    public function get($name) 
    {
        echo "Getting &#39;$name&#39;\n";
        if (array_key_exists($name, $this->data)) {
            return $this->data[$name];
        }

        $trace = debug_backtrace();
        trigger_error(
            &#39;Undefined property via get(): &#39; . $name .
            &#39; in &#39; . $trace[0][&#39;file&#39;] .
            &#39; on line &#39; . $trace[0][&#39;line&#39;],
            E_USER_NOTICE);
        return null;
    }



    /**  PHP 5.1.0之后版本 */
    public function isset($name) 
    {
        echo "Is &#39;$name&#39; set?\n";
        return isset($this->data[$name]);
    }

    /**  PHP 5.1.0之后版本 */
    public function unset($name) 
    {
        echo "Unsetting &#39;$name&#39;\n";
        unset($this->data[$name]);
    }

    /**  非魔术方法  */
    public function getHidden() 
    {
        return $this->hidden;
    }
}


echo "<pre class="brush:php;toolbar:false">\n";

$obj = new PropertyTest;

$obj->a = 1;
echo $obj->a . "\n\n";

var_dump(isset($obj->a));
unset($obj->a);
var_dump(isset($obj->a));
echo "\n";

echo $obj->declared . "\n\n";

echo "Let&#39;s experiment with the private property named &#39;hidden&#39;:\n";
echo "Privates are visible inside the class, so get() not used...\n";
echo $obj->getHidden() . "\n";
echo "Privates not visible outside of class, so get() is used...\n";
echo $obj->hidden . "\n";
?>

다 읽으셨나요? 잘생겼어!

5.sleep, wakeup

sleep은 직렬화를 사용할 때 호출되며 대형 개체의 모든 데이터를 저장할 필요가 없을 때 유용합니다.
wakeup은 unserialize를 사용할 때 호출되며 일부 작업에 사용할 수 있습니다. 객체 초기화 작업

<?php
class Connection 
{
    protected $link;
    private $server, $username, $password, $db;
    
    public function construct($server, $username, $password, $db)
    {
        $this->server = $server;
        $this->username = $username;
        $this->password = $password;
        $this->db = $db;
        $this->connect();
    }
    
    private function connect()
    {
        $this->link = mysql_connect($this->server, $this->username, $this->password);
        mysql_select_db($this->db, $this->link);
    }
    
    public function sleep()
    {
        return array(&#39;server&#39;, &#39;username&#39;, &#39;password&#39;, &#39;db&#39;);
    }
    
    public function wakeup()
    {
        $this->connect();
    }
}
?>

6.clone


은 객체를 복제할 때 호출되며 객체의 복제 동작을 조정하는 데 사용됩니다.

<?php
class SubObject
{
    static $instances = 0;
    public $instance;

    public function construct() {
        $this->instance = ++self::$instances;
    }

    public function clone() {
        $this->instance = ++self::$instances;
    }
}

class MyCloneable
{
    public $object1;
    public $object2;

    function clone()
    {
      
        // 强制复制一份this->object, 否则仍然指向同一个对象
        $this->object1 = clone $this->object1;
    }
}

$obj = new MyCloneable();

$obj->object1 = new SubObject();
$obj->object2 = new SubObject();

$obj2 = clone $obj;


print("Original Object:\n");
print_r($obj);

print("Cloned Object:\n");
print_r($obj2);

?>

7.toString

은 클래스가 문자열로 변환될 때 호출됩니다.

<?php
class SubObject
{
    static $instances = 0;
    public $instance;

    public function construct() {
        $this->instance = ++self::$instances;
    }

    public function clone() {
        $this->instance = ++self::$instances;
    }
}

class MyCloneable
{
    public $object1;
    public $object2;

    function clone()
    {
      
        // 强制复制一份this->object, 否则仍然指向同一个对象
        $this->object1 = clone $this->object1;
    }
}

$obj = new MyCloneable();

$obj->object1 = new SubObject();
$obj->object2 = new SubObject();

$obj2 = clone $obj;


print("Original Object:\n");
print_r($obj);

print("Cloned Object:\n");
print_r($obj2);

?>

8. set_state

이 정적 메서드는 클래스를 내보내기 위해 var_export()가 호출될 때 호출됩니다. var_export의 반환 값으로 set_state의 반환 값을 사용합니다. 아아아아

위 내용은 PHP의 오버로딩 및 매직 메소드 예제에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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