Construct라는 클래스에서 함수를 선언하면 이 함수는 생성자로 간주되어 객체 인스턴스를 생성할 때 실행됩니다. 다른 함수와 마찬가지로 생성자에는 매개변수나 기본값이 있을 수 있습니다. 클래스를 정의하여 개체를 만들고 해당 속성을 모두 문에 넣을 수 있습니다.
PHP가 먼저 호출하는 destruct라는 함수를 정의할 수도 있습니다. 객체는 소멸됩니다.
상속은 클래스의 강력한 기능입니다. 한 클래스(하위 클래스/파생 클래스)는 클래스(상위 클래스/기본 클래스)의 다른 함수를 상속할 수 있습니다. 기본 클래스의 모든 속성 및 메서드를 사용하고 파생 클래스에 다른 속성 및 메서드를 추가할 수도 있습니다. 3.1.2에서 볼 수 있듯이 확장 키워드를 사용할 수도 있습니다.
생성자가 다른 메서드와 함께 상속되면 포함되지 않습니다. 객체를 생성할 때 실행됩니다.이 기능이 필요하면 사용해야 합니다. 2장에서 언급한 :: 연산자.
네임스페이스를 가리킬 수 있습니다. parent는 상위 클래스 네임스페이스를 가리키며, parent::construct를 사용하여 상위 클래스의 생성자를 호출할 수 있습니다. 언어는 클래스 뒤에 생성자를 지정합니다. 이전 버전의 PHP에서도 마찬가지였으며 이 메서드는 여전히 작동합니다. 즉, Animal 클래스의 이름을 지정하고 그 안에 Animal이라는 메서드를 생성하면 이 메서드가 생성자가 됩니다. 클래스에 클래스와 동일한 이름을 가진 생성자와 함수가 모두 있는 경우 PHP는 생성자로 처리합니다. 이로 인해 PHP 버전에서 작성된 이전 클래스를 계속 사용할 수 있습니다. 생성자를 사용해야 합니다.
1 < ?php 2 3 class Counter { private static $count = 0; 4 5 function construct() { self::$count++; } 6 7 function destruct() { self::$count--; } 8 9 function getCount() { return self::$count; } } 10 11 //建立第一个实例 12 13 $c = new Counter(); 14 15 //输出1 16 17 print($c->getCount() . "<br>\n"); 18 19 //建立第二个实例 20 21 $c2 = new Counter(); 22 23 //输出2 24 25 print($c->getCount() . "<br>\n"); 26 27 //销毁实例 28 29 $c2 = NULL; 30 31 //输出1 32 33 print($c->getCount() . "<br>\n"); 34 35 ?>
참고:
생성자가 하위 클래스에 정의된 경우 상위 클래스의 생성자는 암시적으로 호출되지 않습니다. 상위 클래스의 생성자를 실행하려면 하위 클래스의 생성자에서parent::construct()를 호출해야 합니다. 하위 클래스가 생성자를 정의하지 않으면 일반 클래스 메서드와 마찬가지로 상위 클래스에서 상속됩니다(private으로 정의되지 않은 경우).
예제 #1 새로운 표준 생성자 사용하기<?phpclass BaseClass {
function construct() {
print "In BaseClass constructor\n";
}
}class SubClass extends BaseClass {
function construct() {
parent::construct();
print "In SubClass constructor\n";
}
}class OtherSubClass extends BaseClass {
// inherits BaseClass's constructor}
// In BaseClass constructor$obj = new BaseClass();
// In BaseClass constructor
// In SubClass constructor$obj = new SubClass();
// In BaseClass constructor$obj = new OtherSubClass();?>
与其它方法不同,当 construct() 被与父类 construct() 具有不同参数的方法覆盖时,PHP 不会产生一个 E_STRICT
错误信息。
自 PHP 5.3.3 起,在命名空间中,与类名同名的方法不再作为构造函数。这一改变不影响不在命名空间中的类。
Example #2 Constructors in namespaced classes
<?php namespace Foo; class Bar { public function Bar() { // treated as constructor in PHP 5.3.0-5.3.2 // treated as regular method as of PHP 5.3.3 } } ?>
void destruct ( void )
PHP 5 引入了析构函数的概念,这类似于其它面向对象的语言,如 C++。析构函数会在到某个对象的所有引用都被删除或者当对象被显式销毁时执行。
Example #3 析构函数示例
<?php class MyDestructableClass { function construct() { print "In constructor\n"; $this->name = "MyDestructableClass"; } function destruct() { print "Destroying " . $this->name . "\n"; } }$obj = new MyDestructableClass();?>
和构造函数一样,父类的析构函数不会被引擎暗中调用。要执行父类的析构函数,必须在子类的析构函数体中显式调用 parent::destruct()。此外也和构造函数一样,子类如果自己没有定义析构函数则会继承父类的。
析构函数即使在使用 exit() 终止脚本运行时也会被调用。在析构函数中调用 exit() 将会中止其余关闭操作的运行。
위 내용은 PHP 소멸자의 샘플 코드 공유의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!