수업 구조: 클래스의 내부 함수에는 상수, 속성, 메서드라는 세 가지가 있을 수 있습니다. 함수는 클래스 외부의 상수, 변수 및 함수로 이해될 수 있습니다.
코드는 다음과 같습니다.
<?php class TEST { const NAME = 'value'; // 常量 public $name = 'value'; // 属性 public function name() // 方法 { echo 'value'; } } ?>
여기서 속성과 메서드는 public, protected, private의 세 가지 키워드를 사용하여 속성과 메서드의 범위를 더욱 구분할 수 있습니다. protected 키워드가 있는 속성 및 메서드는 자신뿐만 아니라 자체 상위 클래스의 메서드에서도 호출할 수 있으며 public 키워드가 있는 메서드도 호출할 수 있습니다. 호출된 메소드는 인스턴스화 후 객체에서 호출될 수 있습니다. 이것의 가장 큰 장점은 모든 속성과 메소드에 몇 가지 설명 기능을 추가하여 코드 구조를 더 쉽게 구성하고 구성할 수 있다는 것입니다. const 키워드는 먼저 건너뛰고 나중에 static과 함께 논의됩니다.
정적 키워드는 public, protected, private과 다른 또 다른 유형의 키워드입니다(따라서 public, protected, private과 조합하여 사용할 수 있음).
코드는 다음과 같습니다.
<?php class TEST { public static function name() { echo 'value'; } } ?>
with static 키워드 클래스를 인스턴스화하지 않고 "::" 기호를 통해 메소드를 직접 호출할 수 있습니다. public, protected 및 private과의 조합을 사용하면 호출에서 권한을 구분할 수도 있지만 일반적으로 앞서 언급한 것처럼 public과 쌍을 이룹니다. 키워드 const는 공개 정적 유형이어야 하므로 상수는 self::NAME 및 TEST::NAME과 같은 형식을 통해서만 호출할 수 있습니다. 후속 __construct, __destruct 및 기타 메서드는 모두 정적입니다.
클래스의 구조적 부분에서 소개된 마지막 두 키워드는 abstract와 final입니다. abstract 키워드는 이 클래스를 하위 클래스로 덮어쓰면 안 된다는 의미이고, final 키워드는 이 클래스를 하위 클래스로 덮어쓰면 안 된다는 의미입니다. , 이 두 키워드의 기능은 정반대입니다. 추상이 있는 메서드를 추상 메서드라고 하고, 추상 메서드가 있는 클래스를 추상 클래스라고 합니다.
클래스 사용법:
클래스를 사용하는 방법에는 크게 두 가지가 있습니다. 하나는 new 키워드를 사용하는 것이고, 다른 하나는 "::" 기호를 사용하는 것입니다.
PHP 코드
코드는 다음과 같습니다.
<?php class TEST { public static function name() { echo 'value'; } } //方法1:使用new关键字 $test = new TEST; $test->name(); //方法2:使用“::”符号 TEST::name(); ?>
(1): new 키워드를 사용하여 인스턴스화합니다. 위의 $test는 TEST 클래스를 인스턴스화하여 생성된 개체이며 $test->name()은 $test 개체의 name 메서드라고 합니다. .
(2): 클래스를 사용하기 위해 new 키워드를 사용할 때 $this를 사용하여 클래스 자체를 참조할 수 있습니다.
(3): "::" 기호를 사용하기 위한 전제 조건은 메서드에 static 키워드가 있어야 한다는 것입니다. new 키워드를 사용할 때 호출되는 메서드에는 public 키워드가 있어야 합니다(메서드에 public, protected가 없으면) , private의 모든 키워드는 기본적으로 public으로 설정됩니다.)
(4): 동일한 클래스는 new 키워드를 통해 여러 개의 다른 개체로 인스턴스화될 수 있지만 서로 격리됩니다. "::" 기호를 사용하면 메서드가 공유됩니다. 다중 사용 사이:
PHP 코드
코드는 다음과 같습니다:
<?php class TEST1 { public $name = 0; public function name() { $this->name = $this->name + 1; } } $test1 = new TEST1; $test2 = new TEST1; $test1->name(); //$name1 == 1 $test2->name(); //$name1 == 1 /*--------------------------------------------*/ class TEST2 { public static $name = 0; public static function name() { TEST2::$name = TEST2::$name + 1; } } TEST2::name(); // $name == 1 TEST2::name(); // $name == 2 ?>
클래스 사이의 관계:
클래스 사이의 관계는 주로 추상화, 인터페이스 및 상속을 포함합니다:
PHP 코드
코드는 다음과 같습니다. :
<?php abstract class TEST1 // 抽象 { abstract public function name1(); public function name2() { } } class TEST2 extends TEST1 implements TEST3 // 继承 { public function name1() { } } interface TEST3 // 接口 { public function name2(); } ?>
(1) abstract 키워드가 있는 클래스는 추상 클래스이고, abstract 키워드가 있는 메서드는 추상 메서드입니다. 추상 클래스의 추상 메서드는 하위 클래스에서 재정의되어야 합니다.
(2) 인터페이스 키워드가 있는 클래스는 인터페이스입니다. 인터페이스는 어떤 메서드의 구현도 허용하지 않습니다. 인터페이스의 모든 메서드는 하위 클래스에서 재정의되어야 합니다.
(3) classA가 classB를 확장하거나 classA가 classB를 구현한다는 단어는 상속입니다. 확장은 다른 클래스를 상속하는 것을 의미하고 구현은 한 번에 하나의 클래스만 확장할 수 있지만 여러 인터페이스를 구현할 수 있다는 의미입니다.
(4) 추상 클래스, 인터페이스 및 궁극적으로 상속되고 구현된 메서드는 공개되어야 합니다.
상속 과정에서 하위 클래스는 동일한 이름으로 상위 클래스의 메서드를 덮어쓰게 됩니다. 이때 하위 클래스에서 상위 클래스의 메서드를 호출해야 하는 경우 parent 키워드나 클래스를 사용할 수 있습니다. 이름과 호출할 "::" 기호:
PHP 코드
코드는 다음과 같습니다.
<?php class TEST1 extends TEST2 { public function name() { echo parent::name2(); echo TEST2::name2(); } } class TEST2 { public function name2() { echo 'value2'; } } $test = new TEST1; $test->name(); ?>
여기 클래스에서 "::" 메소드의 역할에 대한 또 다른 설명이 있습니다. 인스턴스화 없이 상수(실제로는 static으로도 이해될 수 있음), 정적 속성 및 메서드를 호출하는 방법과 다른 하나는 self, parent 및 클래스 이름을 통해 클래스 내부에 편리한 호출 채널을 설정하는 것입니다.
객체 간의 관계는 주로 "==" 같음, "===" 모두 같음, 같지 않음 및 복제입니다.
PHP 코드
<?php class TEST { public function name() { } } $test1 = new TEST; $test2 = new TEST; $test3 = $test1; echo $test1 == $test2 ? true : false; // true echo $test1 == $test3 ? true : false; // true echo $test2 == $test3 ? true : false; // true echo $test1 === $test2 ? true : false; // false echo $test1 === $test3 ? true : false; // true echo $test2 === $test3 ? true : false; // false ?>
(1)两个类只要拥有相同的属性和方法,就是“==”等于。
(2)两个类必须是指向的同一个对象,才能是“===”全等于。
clone比较特殊,在上面的例子中,$test3 = $test1的过程并不是给了 $test3 一份 $test1 对象的拷贝,而是让 $test3 指向了 $test1,如果一定要获得一份$test1的拷贝,就必须使用clone关键字:
PHP代码
代码如下:
<?php $test3 = clone $test1; ?>
类的钩子:
__autoload:
是一个函数名,也是唯一一个在类的外部使用的钩子,在实例化一个对象的时候,如果没有预先载入类,就会调用这个钩子。
__construct
在类被实例话的时候,被调用的钩子,可以做一些初始化的操作。
__destruct
在类被销毁的时候,被调用的钩子。
__call
当对象试图调用一个不存在的方法的时候,被调用的钩子
__sleep
当使用serialize()函数对一个类进行序列话操作的时候,会调用这个钩子
__wakeup
当使用unserialize()函数对一个类进行反序列话操作的时候,会调用这个钩子
__toString
当一个对象将被转变为字符串的时候,会调用这个钩子(比如echo的时候)
__set_state
当调用var_export()函数操作一个类的时候,会调用这个钩子
__clone
当使用clone关键字对一个类进行拷贝操作的时候,会调用这个钩子
__get
在获取一个类中的属性值的时候,会调用这个钩子
__set
在设置一个类中的属性值的时候,会调用这个钩子
__isset
在使用isset()函数对类中的属性值进行判定的时候,会调用这个钩子
__unset
在使用unset()函数销毁一个属性值的时候,会调用这个钩子
类的小技巧:
在实例话一个类的时候,可以使用这样的形式给__construct钩子传递参数:
PHP代码
代码如下:
<?php class TEST { public function __construct($para) { echo $para; } } $test = new TEST('value'); // 显示 value ?>
foreach()函数可以用来对类或者对象中的属性进行遍历,遍历的时候会先判断public, protected, private的情况而显示:
PHP代码
代码如下:
<?php class TEST { public $property1 = 'value1'; public $property2 = 'value2'; public $property3 = 'value3'; public function name() { foreach($this as $key => $value) { print "$key => $value\n"; } } } $test = new TEST; foreach($test as $key => $value) { print "$key => $value\n"; } $test->name(); ?>
在给类中的方法传递参数的时候,可以对参数进行强制的判定,这里只支持对数组和对象的判定:
PHP代码
代码如下:
<?php class TEST1 { public function name( TEST2 $para ) { } } class TEST2 { } $test2 = new TEST2; $test1 = new TEST1; $test1->name('value'); // 会报错,因为这个参数必须是TEST2实例化以后的对象 $test1->name($test1); // 不会报错 ?>
兼容php4的语法:
php5的类是往下兼容php4的,这些php4时代的语法也得到了继承,但是并不建议在php5的环境中使用。
(1)使用var预设属性,会自动转换成public。
(2)使用类名作为构造函数,在没有__construct构造方法的情况下,会寻找和类名相同的函数作为构造函数。
위 내용은 PHP로 수업을 배우는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!