>  기사  >  백엔드 개발  >  PHP 클래스의 변수 및 멤버, 상속, 액세스 및 재정의 시 주의할 사항

PHP 클래스의 변수 및 멤버, 상속, 액세스 및 재정의 시 주의할 사항

WBOY
WBOY원래의
2016-07-25 09:03:11933검색
  1. class Myclass{

  2. public $prop = 123;
  3. }

  4. $obj = new Myclass();

  5. ?>

코드 복사

클래스 멤버 속성(속성 이름은 "메소드"에 상대적임)에는 클래스 상수와 클래스 변수가 포함됩니다. 정의 시 클래스 상수는 비어 있을 수 없습니다. 클래스 속성에 정의 시 값이 할당되면 스칼라와 배열만 사용할 수 있습니다. 클래스 속성은 컴파일 타임에 초기화되고 PHP는 컴파일 타임에 표현식을 실행하지 않으므로 표현식이 될 수 없습니다.

1. 회원 액세스 제어 : public: 상속될 수 있으며 $obj->prop와 같은 클래스 메서드 외부에서 액세스할 수 있습니다. protected: 상속될 수 있지만 클래스 메서드 외부에서는 접근할 수 없습니다. private: 상속될 수 없으며 클래스 메서드 외부에서 액세스할 수 없습니다

PHP 4에서는 var를 사용하여 클래스 속성을 선언합니다. PHP5 이후에는 더 이상 사용되지 않습니다. PHP5.3 이전에는 경고가 표시됩니다. PHP5.3 이후에는 public 앞에 사용하거나 public의 별칭으로 단독으로 사용할 수 있습니다.

이 세 가지 액세스 제어 키워드는 생성자를 수정할 수도 있습니다. private 및 protected가 클래스의 생성자를 수정하는 경우 생성자를 호출하여 publice 정적 정적 메서드를 통해서만 객체를 인스턴스화할 수 있습니다. 왜냐하면 함수에서는 충분하기 때문입니다. 싱글톤 클래스 구현과 같이 클래스 외부에서 액세스할 수 없습니다.

  1. class Singleton {
  2. private static $instance=null;
  3. public $ k = 88;
  4. 비공개 함수 __construct(){

  5. }

  6. 공개 정적 함수 getInstance(){

  7. if( self::$instance==null){
  8. self::$instance = new self();
  9. }

  10. return self::$instance;

  11. }

  12. public function __clone(){ //복제 작업 척

  13. throw('싱글톤 클래스는 복제할 수 없습니다.');
  14. return self::getInstance();
  15. }
  16. }

  17. //new Singleton(); // 오류

  18. $in = Singleton::getInstance()
  19. ?> ;/p>
코드 복사

2. 상속 금지: 최종 키워드만 사용 수업이나 수업을 수정하는 방법

클래스가 final로 수정되면 이 클래스는 상속될 수 없습니다. 메소드가 final로 수정되면 이 메소드는 하위 클래스로 재정의될 수 없습니다.

  1. class Myclass{
  2. public $prop = 123;
  3. final public static function methodA(){// 상속 불가능한 공개 정적 메서드
  4. return '이것이 최종 메서드입니다';
  5. }
  6. }
  7. ?>
코드 복사

3. 추상 클래스 및 추상 메소드 : 추상 클래스는 클래스 및 메소드에만 사용되며 객체를 인스턴스화하는 데 직접 사용할 수 없으며 하위 클래스를 생성하는 데만 사용할 수 있습니다.

  1. 추상 클래스 Myclass{
  2. public $prop = 123;
  3. abstract public function methodA(); 추상 메서드는 함수 본문
  4. }
  5. ?>
코드 복사

4. 해당 액세스 : 클래스 상수는 액세스 제한 수정자를 사용할 수 없습니다. 이는 공개적이고 상속 가능하며 클래스 상수에 액세스하려면 이중 콜론::을 사용해야 합니다. 수업의 예를 들어보세요.

  1. class Myclass{
  2. public $prop = 123;
  3. const x = 999;

  4. public static function methodA(){

  5. return '이것은 최종 메소드입니다';
  6. }

  7. function getConst(){

  8. return self::x; //또는 $this::x;
  9. }
  10. }

  11. $instance = new Myclass() ;

  12. echo Myclass::x;

  13. echo $instance::x;
  14. echo $instance->getConst();
  15. ?>
코드 복사

클래스 상수는 값입니다. 상수 이름은 코드 컴파일 중에 해당 값으로 대체되며 런타임 중에는 수정할 수 없습니다. 따라서 클래스 상수는 클래스 자체와 관련되어 있으며 객체가 인스턴스화되기 전에 이미 존재합니다. 클래스의 상수는 클래스 이름을 사용하여 직접 액세스할 수 있습니다.

  1. class P{
  2. const m = 100;
  3. const n = self ::m;
  4. }

  5. class S 확장 P{

  6. const m=200;
  7. public function getPConst(){
  8. return parent::n ;
  9. }
  10. }

  11. $p = new P();

  12. $s = new S();
  13. echo $p::n; //100
  14. echo $s::n; //200 이 상수 이름은 상위 클래스에서 상속되며 컴파일 중에 self::m의 값으로 대체됩니다. self::m
  15. echo $s->getPConst() //100

  16. ?>

코드 복사

5. 정적 멤버 및 클래스 액세스

static은 클래스의 속성과 메서드를 수정할 수 있습니다. static으로 수정된 멤버는 클래스의 인스턴스가 아니라 클래스에 속합니다. 정적 멤버는 클래스 이름과 이중 콜론::을 사용하여 액세스해야 합니다. 따라서 정적 메서드 내에서는 인스턴스 자체를 가리키는 의사 변수 $this(또는 일반적으로 $this 포인터라고도 함)를 사용하는 것이 금지됩니다. 클래스 이름 대신 self 키워드를 사용할 수 있습니다. 클래스의 매직 상수 __CLASS__).

정적은 클래스 생성자를 수정하는 데 사용할 수 없으며 인터페이스에 선언된 메서드를 수정하는 데 사용할 수도 없습니다.

  1. class Myclass{
  2. public static $x = 99;

  3. 공용 함수 getX(){

  4. return self::$x;
  5. }
  6. }

  7. echo Myclass::x; /99

  8. ?>

코드 복사

정적 멤버는 액세스 제어 키워드로 수정이 가능하며 상속 및 재정의, 하위 클래스가 메서드를 재정의하지 않고 상위 클래스의 정적 메서드를 상속하는 경우 하위 클래스는 실제로 상위 클래스의 정적 메서드를 호출한다는 점에 유의해야 합니다. 정적 멤버 홀더는 개체가 아니라 클래스이므로 클래스의 여러 인스턴스가 동일한 정적 속성을 공유합니다. 한 인스턴스에서 정적 속성을 수정하면 다른 인스턴스의 정적 속성에 영향을 미칩니다.

  1. 클래스 A{

  2. a1 = 11;

  3. 공개 $a2 = 22;

  4. 공개 정적 함수 showStatic(){

  5. return self::$a1;
  6. }
  7. 공용 함수 getStatic(){

  8. return self::$a1;
  9. }

  10. 공용 함수 getClassStatic(){

  11. $ className = get_called_class();
  12. return $className::$a1;
  13. }

  14. public function getProp(){

  15. return $this->a2;
  16. }
  17. }

  18. 클래스 B 확장 A{

  19. public static $a1 = 88;
  20. public $a2 = 99;
  21. }< /p>
  22. $obj1 = new A();

  23. $obj2 = new B();

  24. echo A::showStatic() / /11

  25. echo $obj1->getStatic(); //11
  26. echo $obj1->getClassStatic() //11
  27. echo $obj1->getProp() //22 ;/p>
  28. echo B::showStatic(); //11 상위 클래스의 메서드를 호출하고 상위 클래스의 정적 멤버에 액세스합니다

  29. echo $obj2->getStatic() ; / /11 상위 클래스의 메소드가 호출되고 메소드의 self는 정적 메소드를 보유하는 클래스를 가리킵니다.
  30. echo $obj2->getClassStatic() //88
  31. echo $obj2-> ;getProp() ; //99
  32. ?>
코드 복사

후기 정적 바인딩: 하위 클래스가 정적 속성을 재정의하고 상속된 메서드를 사용하여 상위 클래스의 정적 속성에 액세스하는 것을 방지하기 위해 PHP5.3에서는 정적 키워드를 사용하는 후기 정적 바인딩이라는 새로운 구문을 추가합니다. static이 get_called_class()에 의해 반환된 동일한 클래스, 즉 현재 정적 메서드를 호출하는 객체가 속한 클래스를 가리키도록 하는 키워드입니다. 이 키워드는 정적 메서드에 액세스하는 데에도 유효합니다.

  1. 공용 함수 getClassStatic(){
  2. $className = get_called_class()
  3. return $className::$a1;
  4. }

  5. //다음과 같이 쓸 수 있습니다:

  6. public function getClassStatic(){
  7. return static::$a1 ;
  8. }

  9. //정적 메서드에 사용됨

  10. //클래스 A:
  11. public static function testStatic(){
  12. echo "";
  13. }

  14. 공용 함수 callStatic(){

  15. static::testStatic();
  16. }
  17. //클래스 B:

  18. public static function testStatic(){
  19. echo "

    testStatic of B

    ";
  20. }
  21. / /Class B는 클래스 A의 callStatic 메소드를 상속하며 해당 클래스의 testStatic 메소드에 올바르게 액세스할 수 있습니다.
  22. ?>

코드 복사

6. 클래스 또는 인스턴스 키워드 $this->propName $this는 클래스의 인스턴스를 가리킵니다. parent::xxx parent는 상위 클래스를 가리킵니다. 상위 클래스(parent::$xxx)의 정적 상수 및 정적 속성에 액세스할 수 있습니다. 메서드를 호출할 수 있습니다. 상위 클래스(정적 여부에 관계없이 개인 메소드일 수 없음) self::xxx self는 현재 호출된 메서드를 정의하는 클래스를 가리키며 정적 멤버 및 클래스 상수에 액세스하는 데 사용됩니다. static::xxx는 현재 메서드를 호출한 인스턴스를 인스턴스화한 클래스에 액세스하고 정적 멤버 및 피곤한 상수에 액세스하는 데 사용됩니다. 이 클래스와 self의 차이점은 정적 멤버에 액세스할 때 "후기 정적 바인딩"이 사용된다는 것입니다.

7. 클래스 상속 문제 다시 작성: 재정의된 멤버의 액세스 제어 수준은 줄일 수 없습니다. 예를 들어 public 멤버는 protected로 재정의될 수 없습니다. 비정적 멤버는 정적 멤버로 재정의될 수 없으며 정적 멤버는 비정적 멤버로 재정의될 수 없습니다.

8. 인터페이스에 정의된 메소드는 공개되어야 합니다. 클래스가 인터페이스 메서드를 구현할 때 이러한 메서드도 공개적이고 구체적으로 구현되어야 합니다(추상적일 수 없음). 인터페이스는 인터페이스 상수를 정의할 수도 있으며 사용법은 클래스 상수와 정확히 동일하지만 인터페이스는 함수가 아닌 멤버를 정의할 수 없습니다. 인터페이스는 서로 상속될 수 있습니다. 인터페이스의 상속은 쉼표로 구분된 다중 상속일 수 있습니다(하위 클래스와 상위 클래스의 상속은 단일 상속입니다). 클래스는 쉼표로 구분된 여러 인터페이스를 구현할 수 있습니다.

  1. 인터페이스 Ix는 Iy,Iz를 확장합니다{
  2. 공용 함수 a();
  3. }
  4. 클래스 A는 Iy,Iz를 구현합니다{
  5. .......
  6. }
  7. ?>
코드 복사

9. 유형 제약

PHP의 함수(또는 클래스 메소드)는 선언 시 매개변수의 유형을 제한할 수 있지만 배열 또는 객체(클래스/인터페이스)로만 제한할 수 있습니다. 문자열 유형으로 제한되면 PHP는 이를 제한되는 것으로 간주합니다. 문자열 클래스에.

유형이 인터페이스로 정규화된 경우 전달된 매개변수는 인터페이스를 구현하는 클래스의 인스턴스여야 합니다.

인터페이스 구현과 하위 클래스가 상위 클래스 메서드를 재정의하는 경우 정규화된 매개변수 유형을 수정할 수 없습니다.

메서드나 함수를 호출할 때 정규화된 매개변수 유형과 다른 데이터가 전달되면 오류가 보고되지만 null 매개변수는 허용될 수 있습니다.

  1. 인터페이스 Im{
  2. 공용 함수 a( classm $m);
  3. }

  4. class A Implements Im{

  5. public function a($x){ // 오류, 매개변수 $x는 인터페이스 정의와 일치하도록 classm 유형으로 제한되어야 합니다.
  6. var_dump ($x);
  7. }
  8. }
  9. ?>

코드 복사


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