백엔드 개발 PHP 튜토리얼 php教程之魔术方法的使用示例(php魔术函数)_php实例

php教程之魔术方法的使用示例(php魔术函数)_php实例

May 17, 2016 am 08:49 AM
PHP 튜토리얼 마법의 방법

复制代码 代码如下:

/** PHP把所有以__(两个下划线)开头的类方法当成魔术方法。所以你定义自己的类方法时,不要以 __为前缀。 * */

// __toString、__set、__get__isset()、__unset()
/*
  The __toString method allows a class to decide how it will react when it is converted to a string.
  __set() is run when writing data to inaccessible members.
  __get() is utilized for reading data from inaccessible members.
  __isset() is triggered by calling isset() or empty() on inaccessible members.
  __unset() is invoked when unset() is used on inaccessible members.
 */
class TestClass {

    private $data = array();
    public $foo;

    public function __construct($foo) {
        $this->foo = $foo;
    }

    public function __toString() {
        return $this->foo;
    }

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

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

    /** As of PHP 5.1.0 */
    public function __isset($name) {
        echo "__isset, Is '$name' set?\n";
        return isset($this->data[$name]);
    }

    /** As of PHP 5.1.0 */
    public function __unset($name) {
        echo "__unset, Unsetting '$name'\n";
        unset($this->data[$name]);
    }

}

$obj = new TestClass('Hello');
echo "__toString, $obj\n";
$obj->a = 1;
echo $obj->a . "\n\n";
var_dump(isset($obj->a));
unset($obj->a);
var_dump(isset($obj->a));
echo "\n\n";
/**
  输出结果如下:
  __toString, Hello
  __set, Setting 'a' to '1'
  __get, Getting 'a'
  __isset, Is 'a' set?
  bool(true)
  __unset, Unsetting 'a'
  __isset, Is 'a' set?
  bool(false)
 **/

 

// __call  __callStatic
/*
  mixed __call ( string $name , array $arguments )
  mixed __callStatic ( string $name , array $arguments )
  __call() is triggered when invoking inaccessible methods in an object context.
  __callStatic() is triggered when invoking inaccessible methods in a static context.
  The $name argument is the name of the method being called.
  The $arguments argument is an enumerated array containing the parameters passed to the $name'ed method.
 */
class MethodTest {
    public function __call($name, $arguments) {
        // Note: value of $name is case sensitive.
        echo "__call, Calling object method '$name' " . implode(', ', $arguments) . "\n";
    }

    /** As of PHP 5.3.0 */
    public static function __callStatic($name, $arguments) {
        // Note: value of $name is case sensitive.
        echo "__callStatic, Calling static method '$name' " . implode(', ', $arguments) . "\n";
    }

}

$obj = new MethodTest;
$obj->runTest('in object context', 'param2', 'param3');
//MethodTest::runTest('in static context'); // As of PHP 5.3.0
echo "\n\n";
/**
 输出结果如下:
 __call, Calling object method 'runTest' in object context, param2, param3
  string(10) "__invoke: "
 */

 

// __invoke
/*
  The __invoke method is called when a script tries to call an object as a function.
  Note: This feature is available since PHP 5.3.0.
*/
class CallableClass {
    function __invoke($x) {
        var_dump($x);
    }
}

$obj = new CallableClass;
//$obj(5);
var_dump('__invoke: ' . is_callable($obj));
echo "\n\n";

 

 

// __sleep  __wakeup
/*
  串行化serialize可以把变量包括对象,转化成连续bytes数据. 你可以将串行化后的变量存在一个文件里或在网络上传输.
  然后再反串行化还原为原来的数据. 你在反串行化类的对象之前定义的类,PHP可以成功地存储其对象的属性和方法.
  有时你可能需要一个对象在反串行化后立即执行. 为了这样的目的,PHP会自动寻找__sleep和__wakeup方法.
  当一个对象被串行化,PHP会调用__sleep方法(如果存在的话). 在反串行化一个对象后,PHP 会调用__wakeup方法.
  这两个方法都不接受参数. __sleep方法必须返回一个数组,包含需要串行化的属性. PHP会抛弃其它属性的值.
  如果没有__sleep方法,PHP将保存所有属性.下面的例子显示了如何用__sleep和__wakeup方法来串行化一个对象.
  Id属性是一个不打算保留在对象中的临时属性. __sleep方法保证在串行化的对象中不包含id属性.
  当反串行化一个User对象,__wakeup方法建立id属性的新值. 这个例子被设计成自我保持.
  在实际开发中,你可能发现包含资源(如图像或数据流)的对象需要这些方法
 */

class User {

    public $name;
    public $id;

    function __construct() {
        //give user a unique ID 赋予一个差别 的ID
        $this->id = uniqid();
    }

    //__sleep返回值的类型是数组,数组中的值是不需要串型化的字段id

    function __sleep() {
        //do not serialize this->id 不串行化id
        return(array("name"));
    }

    function __wakeup() {
        //give user a unique ID
        $this->id = uniqid();
    }

}

//create object 成立一个器材
$u = new User;
$u->name = "Leon"; //serialize it 串行化 留意不串行化id属性,id的值被遗弃
$s = serialize($u);
echo "__sleep, __wakeup, s: $s"; //unserialize it 反串行化 id被重新赋值
$u2 = unserialize($s); //$u and $u2 have different IDs $u和$u2有差别 的ID
print_r($u);
print_r($u2);
echo "\n\n";
/**
 输出结果如下:
  __sleep, __wakeup, s: O:4:"User":1:{s:4:"name";s:4:"Leon";}
  User Object
  (
  [name] => Leon
  [id] => 4db1b17640da1
  )
  User Object
  (
  [name] => Leon
  [id] => 4db1b17640dbc
  )
 */


// __set_state
/*
  This static method is called for classes exported by var_export() since PHP 5.1.0.
  The only parameter of this method is an array containing exported properties in the form array('property' => value, ...).
 */

class A {

    public $var1;
    public $var2;

    public static function __set_state($an_array) { // As of PHP 5.1.0
        //$an_array打印出来是数组,而不是调用时传递的对象
        print_r($an_array);
        $obj = new A;
        $obj->var1 = $an_array['var1'];
        $obj->var2 = $an_array['var2'];
        return $obj;
    }

}

$a = new A;
$a->var1 = 5;
$a->var2 = 'foo';
echo "__set_state:\n";
eval('$b = ' . var_export($a, true) . ';');
// $b = A::__set_state(array(
// 'var1' => 5,
// 'var2' => 'foo',
// ));
var_dump($b);
echo "\n\n";
/**
  输出结果如下:
  __set_state:
  Array
  (
  [var1] => 5
  [var2] => foo
  )
  object(A)#5 (2) {
  ["var1"]=>
  int(5)
  ["var2"]=>
  string(3) "foo"
  }
 */

 

// __clone
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() {
        // Force a copy of this->object, otherwise
        // it will point to same object.
        $this->object1 = clone $this->object1;
    }

}

$obj = new MyCloneable();
$obj->object1 = new SubObject();
$obj->object2 = new SubObject();
$obj2 = clone $obj;
print("__clone, Original Object:\n");
print_r($obj);
print("__clone, Cloned Object:\n");
print_r($obj2);
echo "\n\n";
/**
 输出结果如下:
 __clone, Original Object:
  MyCloneable Object
  (
  [object1] => SubObject Object
  (
  [instance] => 1
  ) [object2] => SubObject Object
  (
  [instance] => 2
  ))
  __clone, Cloned Object:
  MyCloneable Object
  (
  [object1] => SubObject Object
  (
  [instance] => 3
  ) [object2] => SubObject Object
  (
  [instance] => 2
  ))
 */

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Python 메타프로그래밍 이해하기: 기초부터 고급 패러다임까지 Python 메타프로그래밍 이해하기: 기초부터 고급 패러다임까지 Feb 19, 2024 pm 03:30 PM

Python 메타프로그래밍 기본 Python 메타프로그래밍은 Python 코드를 동적으로 조작하는 기능으로 Python을 매우 강력한 언어로 만듭니다. 메타프로그래밍은 다음과 같은 방식으로 구현될 수 있습니다. 클래스 데코레이터: 클래스 데코레이터는 클래스 정의를 수정하는 데코레이터입니다. 클래스의 속성과 메서드를 추가하거나 수정하는 데 사용할 수 있으며 클래스의 인스턴스화 프로세스를 제어하는 ​​데에도 사용할 수 있습니다. defadd_method_to_class(cls):defnew_method(self):print("Thisisanewmethod")setattr(cls,"new_method",new_method)returncls@a

PHP 및 phpSpider 튜토리얼: 빠르게 시작하는 방법은 무엇입니까? PHP 및 phpSpider 튜토리얼: 빠르게 시작하는 방법은 무엇입니까? Jul 22, 2023 am 09:30 AM

PHP 및 phpSpider 튜토리얼: 빠르게 시작하는 방법은 무엇입니까? 서문: 오늘날 정보 폭발 시대에 우리는 매일 수많은 웹 페이지와 웹사이트를 탐색합니다. 때로는 분석 및 처리를 위해 웹페이지에서 특정 데이터를 크롤링해야 할 수도 있습니다. 이를 위해서는 웹 크롤러(WebSpider)를 사용하여 웹 콘텐츠를 자동으로 크롤링해야 합니다. PHP는 매우 널리 사용되는 프로그래밍 언어이며 phpSpider는 웹 크롤러를 구축하고 관리하기 위해 설계된 강력한 PHP 프레임워크입니다. 이번 글에서는 PHP 사용법을 소개하겠습니다.

PHP 개발: 리플렉션 및 매직 메서드를 사용하여 자동 코드 생성 및 동적 호출 달성 PHP 개발: 리플렉션 및 매직 메서드를 사용하여 자동 코드 생성 및 동적 호출 달성 Jun 15, 2023 pm 04:16 PM

PHP 개발에서 리플렉션과 매직 메서드는 일반적으로 사용되는 두 가지 기술입니다. 자동으로 코드를 생성하거나 특정 함수를 동적으로 호출해야 할 때 리플렉션 및 매직 메서드를 사용하면 코드를 더욱 유연하고 효율적으로 만들 수 있습니다. 이 기사에서는 리플렉션 및 매직 메서드를 사용하여 자동 코드 생성 및 동적 호출을 달성하는 방법을 살펴보겠습니다. Reflection은 PHP에서 제공하는 강력한 도구로, 프로그램이 실행될 때 클래스, 메서드, 속성과 같은 정보를 얻는 데 도움이 됩니다. 리플렉션을 통해 클래스나 객체의 메서드, 속성, 주석과 같은 정보를 동적으로 얻을 수 있습니다.

16가지 PHP 매직 메소드를 안내합니다. 16가지 PHP 매직 메소드를 안내합니다. May 16, 2022 pm 08:45 PM

매직 메소드란 무엇인가요? 이 글은 PHP 개발자가 꼭 알아야 할 16가지 매직 메소드를 소개합니다. 여러분에게 도움이 되기를 바랍니다.

PHP 함수를 위한 매직 메소드 PHP 함수를 위한 매직 메소드 May 19, 2023 am 08:06 AM

PHP는 웹 개발에 널리 사용되는 C 언어를 기반으로 개발된 서버사이드 스크립팅 언어입니다. 함수는 프로그램에서 가장 기본적이고 일반적으로 사용되는 구성 요소 중 하나입니다. PHP는 또한 개발자가 함수를 더 잘 활용하는 데 도움이 되는 함수와 관련된 많은 매직 메서드를 제공합니다. 이번 글에서는 PHP 함수의 매직 메소드와 사용법을 소개하겠습니다. __construct()__construct()는 PHP에서 가장 일반적으로 사용되는 매직 메소드 중 하나이며 초기화를 위한 객체를 생성할 때 자동으로 호출됩니다.

매직 메소드란 무엇입니까? Laravel에서 사용하는 방법 매직 메소드란 무엇입니까? Laravel에서 사용하는 방법 Sep 26, 2022 pm 08:21 PM

매직 메소드란 무엇입니까? 라라벨에서는 어떻게 사용하나요? 다음 글에서는 Laravel에서 PHP 매직 메소드를 적용하는 방법을 소개하겠습니다. 도움이 되길 바랍니다.

PHP 매직 메소드의 실행 순서를 따르는 방법은 무엇입니까? PHP 매직 메소드의 실행 순서를 따르는 방법은 무엇입니까? Apr 17, 2024 pm 09:33 PM

PHP 매직 메소드의 실행 순서는 다음 규칙을 따릅니다. 우선 순위가 높은 매직 메소드가 먼저 실행됩니다. 하위 클래스와 상위 클래스가 모두 동일한 이름의 매직 메서드를 정의하는 경우 하위 클래스의 매직 메서드가 먼저 실행됩니다. 클래스가 동일한 이름을 가진 일반 메소드와 매직 메소드를 모두 정의하는 경우 일반 메소드가 먼저 실행됩니다.

매직 메소드: __construct, __destruct 및 PHP의 기타 핵심 메소드 이해 매직 메소드: __construct, __destruct 및 PHP의 기타 핵심 메소드 이해 Jun 19, 2023 pm 11:22 PM

매직 메소드: PHP의 __construct 및 __destruct와 같은 핵심 메소드를 이해하십시오. PHP 언어에는 __construct, __destruct 등을 포함하여 "매직 메소드"라는 특수 메소드가 있습니다. 이러한 메소드는 PHP의 객체 지향 프로그래밍에서 중요한 역할을 합니다. 이 기사에서는 이러한 방법의 역할과 실제 적용에 대해 설명합니다. __construct 메소드__construct 메소드는 PHP에 있는 매우 중요한 메소드입니다.

See all articles