Hướng dẫn how do you call a class in php? - làm thế nào để bạn gọi một lớp trong php?

class

Các định nghĩa lớp cơ bản bắt đầu bằng từ khóa class, theo sau là tên lớp, theo sau là một cặp niềng răng xoăn bao quanh các định nghĩa của các thuộc tính và phương thức thuộc lớp.

Tên lớp có thể là bất kỳ nhãn hợp lệ nào, miễn là nó không phải là từ dành riêng của PHP. Một tên lớp hợp lệ bắt đầu bằng một chữ cái hoặc dấu gạch dưới, theo sau là bất kỳ số lượng chữ cái, số hoặc nhấn mạnh. Như một biểu hiện chính quy, nó sẽ được thể hiện như vậy:

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
0.

Một lớp có thể chứa các hằng số, biến của chính nó (được gọi là "thuộc tính") và các hàm (được gọi là "Phương thức").

Ví dụ #1 Định nghĩa lớp đơn giản

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
1

$ Biến giả $ này có sẵn khi một phương thức được gọi từ trong bối cảnh đối tượng. $ Đây là giá trị của đối tượng gọi.

Cảnh báo

Gọi một phương thức phi tĩnh là ném một lỗi. Trước Php 8.0.0, điều này sẽ tạo ra thông báo không nhận được và $ Điều này sẽ không được xác định.Error. Prior to PHP 8.0.0, this would generate a deprecation notice, and $this would be undefined.

Ví dụ #2 Một số ví dụ về $ này là giả biến

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
2

class

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
4

Đầu ra của ví dụ trên trong Php 7:

$this is defined (A)

Deprecated: Non-static method A::foo() should not be called statically in %s  on line 27
$this is not defined.

Deprecated: Non-static method A::foo() should not be called statically in %s  on line 20
$this is not defined.

Deprecated: Non-static method B::bar() should not be called statically in %s  on line 32

Deprecated: Non-static method A::foo() should not be called statically in %s  on line 20
$this is not defined.

Đầu ra của ví dụ trên trong Php 8:

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27

new

Để tạo một thể hiện của một lớp, từ khóa

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
5 phải được sử dụng. Một đối tượng sẽ luôn được tạo trừ khi đối tượng có một hàm tạo được xác định để ném một ngoại lệ về lỗi. Các lớp nên được xác định trước khi khởi tạo (và trong một số trường hợp, đây là một yêu cầu).

Nếu một chuỗi chứa tên của một lớp được sử dụng với

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
5, một thể hiện mới của lớp đó sẽ được tạo. Nếu lớp nằm trong không gian tên, tên đủ điều kiện của nó phải được sử dụng khi làm điều này.string containing the name of a class is used with
$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
5, a new instance of that class will be created. If the class is in a namespace, its fully qualified name must be used when doing this.

Ghi chú::

Nếu không có đối số nào được chuyển cho hàm tạo của lớp, ngoặc đơn sau khi tên lớp có thể bị bỏ qua.

Ví dụ #3 Tạo một thể hiện

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
7

Kể từ Php 8.0.0, sử dụng

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
5 với các biểu thức tùy ý được hỗ trợ. Điều này cho phép khởi tạo phức tạp hơn nếu biểu thức tạo ra một chuỗi. Các biểu thức phải được bọc trong ngoặc đơn.string. The expressions must be wrapped in parentheses.

Ví dụ #4 Tạo một thể hiện bằng cách sử dụng biểu thức tùy ý

Trong ví dụ đã cho, chúng tôi hiển thị nhiều ví dụ về các biểu thức tùy ý hợp lệ tạo ra một tên lớp. Điều này cho thấy một cuộc gọi đến một hàm, nối chuỗi và hằng số

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
9.
$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
9
constant.

object(ClassA)#1 (0) {
}
object(ClassB)#1 (0) {
}
object(ClassC)#1 (0) {
}
object(ClassD)#1 (0) {
}

0

object(ClassA)#1 (0) {
}
object(ClassB)#1 (0) {
}
object(ClassC)#1 (0) {
}
object(ClassD)#1 (0) {
}

1

object(ClassA)#1 (0) {
}
object(ClassB)#1 (0) {
}
object(ClassC)#1 (0) {
}
object(ClassD)#1 (0) {
}

2

Đầu ra của ví dụ trên trong Php 8:

object(ClassA)#1 (0) {
}
object(ClassB)#1 (0) {
}
object(ClassC)#1 (0) {
}
object(ClassD)#1 (0) {
}

Để tạo một thể hiện của một lớp, từ khóa

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
5 phải được sử dụng. Một đối tượng sẽ luôn được tạo trừ khi đối tượng có một hàm tạo được xác định để ném một ngoại lệ về lỗi. Các lớp nên được xác định trước khi khởi tạo (và trong một số trường hợp, đây là một yêu cầu).

Nếu một chuỗi chứa tên của một lớp được sử dụng với

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
5, một thể hiện mới của lớp đó sẽ được tạo. Nếu lớp nằm trong không gian tên, tên đủ điều kiện của nó phải được sử dụng khi làm điều này.

Ghi chú:

object(ClassA)#1 (0) {
}
object(ClassB)#1 (0) {
}
object(ClassC)#1 (0) {
}
object(ClassD)#1 (0) {
}

5

object(ClassA)#1 (0) {
}
object(ClassB)#1 (0) {
}
object(ClassC)#1 (0) {
}
object(ClassD)#1 (0) {
}

6

object(ClassA)#1 (0) {
}
object(ClassB)#1 (0) {
}
object(ClassC)#1 (0) {
}
object(ClassD)#1 (0) {
}

7

Nếu không có đối số nào được chuyển cho hàm tạo của lớp, ngoặc đơn sau khi tên lớp có thể bị bỏ qua.

NULL
NULL
object(SimpleClass)#1 (1) {
   ["var"]=>
     string(30) "$assigned will have this value"
}

Ví dụ #3 Tạo một thể hiện

Kể từ Php 8.0.0, sử dụng

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
5 với các biểu thức tùy ý được hỗ trợ. Điều này cho phép khởi tạo phức tạp hơn nếu biểu thức tạo ra một chuỗi. Các biểu thức phải được bọc trong ngoặc đơn.

object(ClassA)#1 (0) {
}
object(ClassB)#1 (0) {
}
object(ClassC)#1 (0) {
}
object(ClassD)#1 (0) {
}

8

class

NULL
NULL
object(SimpleClass)#1 (1) {
   ["var"]=>
     string(30) "$assigned will have this value"
}
0

Nếu không có đối số nào được chuyển cho hàm tạo của lớp, ngoặc đơn sau khi tên lớp có thể bị bỏ qua.

bool(true)
bool(true)
bool(true)

Ví dụ #3 Tạo một thể hiện

Kể từ Php 8.0.0, sử dụng

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
5 với các biểu thức tùy ý được hỗ trợ. Điều này cho phép khởi tạo phức tạp hơn nếu biểu thức tạo ra một chuỗi. Các biểu thức phải được bọc trong ngoặc đơn.

NULL
NULL
object(SimpleClass)#1 (1) {
   ["var"]=>
     string(30) "$assigned will have this value"
}
1

Ví dụ #4 Tạo một thể hiện bằng cách sử dụng biểu thức tùy ý

Trong ví dụ đã cho, chúng tôi hiển thị nhiều ví dụ về các biểu thức tùy ý hợp lệ tạo ra một tên lớp. Điều này cho thấy một cuộc gọi đến một hàm, nối chuỗi và hằng số

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
9.: Prior to PHP 7.1, the arguments are not evaluated if there is no constructor function defined.

Trong bối cảnh lớp, có thể tạo một đối tượng mới bằng object(ClassA)#1 (0) { } object(ClassB)#1 (0) { } object(ClassC)#1 (0) { } object(ClassD)#1 (0) { } 3 và object(ClassA)#1 (0) { } object(ClassB)#1 (0) { } object(ClassC)#1 (0) { } object(ClassD)#1 (0) { } 4.

Khi gán một thể hiện đã được tạo của một lớp cho một biến mới, biến mới sẽ truy cập cùng một thể hiện với đối tượng được gán. Hành vi này là như nhau khi chuyển các trường hợp cho một hàm. Một bản sao của một đối tượng đã được tạo có thể được tạo bằng cách nhân bản nó.

Ví dụ #5 gán đối tượng

NULL
NULL
object(SimpleClass)#1 (1) {
   ["var"]=>
     string(30) "$assigned will have this value"
}
2

NULL
NULL
object(SimpleClass)#1 (1) {
   ["var"]=>
     string(30) "$assigned will have this value"
}
3

NULL
NULL
object(SimpleClass)#1 (1) {
   ["var"]=>
     string(30) "$assigned will have this value"
}
4

Nếu không có đối số nào được chuyển cho hàm tạo của lớp, ngoặc đơn sau khi tên lớp có thể bị bỏ qua.

Ví dụ #3 Tạo một thể hiện

Kể từ Php 8.0.0, sử dụng

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
5 với các biểu thức tùy ý được hỗ trợ. Điều này cho phép khởi tạo phức tạp hơn nếu biểu thức tạo ra một chuỗi. Các biểu thức phải được bọc trong ngoặc đơn.

NULL
NULL
object(SimpleClass)#1 (1) {
   ["var"]=>
     string(30) "$assigned will have this value"
}
5

NULL
NULL
object(SimpleClass)#1 (1) {
   ["var"]=>
     string(30) "$assigned will have this value"
}
3

NULL
NULL
object(SimpleClass)#1 (1) {
   ["var"]=>
     string(30) "$assigned will have this value"
}
7

Nếu không có đối số nào được chuyển cho hàm tạo của lớp, ngoặc đơn sau khi tên lớp có thể bị bỏ qua.

extends

Ví dụ #3 Tạo một thể hiện

Kể từ Php 8.0.0, sử dụng

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
5 với các biểu thức tùy ý được hỗ trợ. Điều này cho phép khởi tạo phức tạp hơn nếu biểu thức tạo ra một chuỗi. Các biểu thức phải được bọc trong ngoặc đơn.

Lưu ý: Kể từ Php 8.1.0, hằng số có thể được khai báo là cuối cùng.: As of PHP 8.1.0, constants may be declared as final.

Ví dụ #10 Kế thừa lớp đơn giản

NULL
NULL
object(SimpleClass)#1 (1) {
   ["var"]=>
     string(30) "$assigned will have this value"
}
9

Ví dụ trên sẽ xuất ra:

Extending class
a default value

Quy tắc tương thích chữ ký

Khi ghi đè một phương thức, chữ ký của nó phải tương thích với phương thức mẹ. Mặt khác, một lỗi nghiêm trọng được phát ra, hoặc, trước Php 8.0.0, một lỗi cấp độ

bool(true)
bool(true)
bool(true)
0 được tạo ra. Chữ ký là tương thích nếu nó tôn trọng các quy tắc phương sai, tạo ra một tham số bắt buộc tùy chọn và nếu bất kỳ tham số mới nào là tùy chọn. Điều này được gọi là nguyên tắc thay thế Liskov, hoặc viết tắt là LSP. Các phương thức xây dựng và
bool(true)
bool(true)
bool(true)
1 được miễn trừ khỏi các quy tắc tương thích chữ ký này và do đó sẽ không phát ra lỗi nghiêm trọng trong trường hợp không khớp chữ ký.
bool(true)
bool(true)
bool(true)
0
level error is generated. A signature is compatible if it respects the variance rules, makes a mandatory parameter optional, and if any new parameters are optional. This is known as the Liskov Substitution Principle, or LSP for short. The constructor, and
bool(true)
bool(true)
bool(true)
1 methods are exempt from these signature compatibility rules, and thus won't emit a fatal error in case of a signature mismatch.

Ví dụ #11 Phương pháp trẻ em tương thích

bool(true)
bool(true)
bool(true)
2

class

bool(true)
bool(true)
bool(true)
4

Ví dụ trên sẽ xuất ra:

Quy tắc tương thích chữ ký

Khi ghi đè một phương thức, chữ ký của nó phải tương thích với phương thức mẹ. Mặt khác, một lỗi nghiêm trọng được phát ra, hoặc, trước Php 8.0.0, một lỗi cấp độ

bool(true)
bool(true)
bool(true)
0 được tạo ra. Chữ ký là tương thích nếu nó tôn trọng các quy tắc phương sai, tạo ra một tham số bắt buộc tùy chọn và nếu bất kỳ tham số mới nào là tùy chọn. Điều này được gọi là nguyên tắc thay thế Liskov, hoặc viết tắt là LSP. Các phương thức xây dựng và
bool(true)
bool(true)
bool(true)
1 được miễn trừ khỏi các quy tắc tương thích chữ ký này và do đó sẽ không phát ra lỗi nghiêm trọng trong trường hợp không khớp chữ ký.

bool(true)
bool(true)
bool(true)
5

class

bool(true)
bool(true)
bool(true)
7

Ví dụ #11 Phương pháp trẻ em tương thích

Fatal error: Declaration of Extend::foo() must be compatible with Base::foo(int $a = 5) in /in/evtlq on line 13

Các ví dụ sau đây chứng minh rằng một phương thức con sẽ loại bỏ tham số hoặc làm cho một tham số tùy chọn bắt buộc, không tương thích với phương thức mẹ.

bool(true)
bool(true)
bool(true)
5

class

Extending class
a default value
0

Ví dụ #11 Phương pháp trẻ em tương thích

Fatal error: Declaration of Extend::foo(int $a) must be compatible with Base::foo(int $a = 5) in /in/qJXVC on line 13

Các ví dụ sau đây chứng minh rằng một phương thức con sẽ loại bỏ tham số hoặc làm cho một tham số tùy chọn bắt buộc, không tương thích với phương thức mẹ.

Ví dụ #12 Lỗi gây tử vong khi phương pháp con xóa tham sốError if named arguments are used.

Đầu ra của ví dụ trên trong Php 8 tương tự như:

Extending class
a default value
1

class

Extending class
a default value
3

Ví dụ #13 Lỗi nghiêm trọng khi phương thức con bắt buộc tham số tùy chọn bắt buộc

Fatal error: Uncaught Error: Unknown named parameter $foo in /in/XaaeN:14
Stack trace:
#0 {main}
  thrown in /in/XaaeN on line 14

::class

Cảnh báo

Đổi tên tham số của một phương thức trong một lớp con không phải là sự không tương thích của chữ ký. Tuy nhiên, điều này không được khuyến khích vì nó sẽ dẫn đến một lỗi thời gian chạy nếu các đối số được đặt tên được sử dụng.

Extending class
a default value
7

Extending class
a default value
8

Extending class
a default value
9

Ví dụ trên sẽ xuất ra:

Quy tắc tương thích chữ ký:

Khi ghi đè một phương thức, chữ ký của nó phải tương thích với phương thức mẹ. Mặt khác, một lỗi nghiêm trọng được phát ra, hoặc, trước Php 8.0.0, một lỗi cấp độ

bool(true)
bool(true)
bool(true)
0 được tạo ra. Chữ ký là tương thích nếu nó tôn trọng các quy tắc phương sai, tạo ra một tham số bắt buộc tùy chọn và nếu bất kỳ tham số mới nào là tùy chọn. Điều này được gọi là nguyên tắc thay thế Liskov, hoặc viết tắt là LSP. Các phương thức xây dựng và
bool(true)
bool(true)
bool(true)
1 được miễn trừ khỏi các quy tắc tương thích chữ ký này và do đó sẽ không phát ra lỗi nghiêm trọng trong trường hợp không khớp chữ ký.

Ví dụ #11 Phương pháp trẻ em tương thích

Fatal error: Declaration of Extend::foo() must be compatible with Base::foo(int $a = 5) in /in/evtlq on line 13
1

Ví dụ trên sẽ xuất ra:

Các ví dụ sau đây chứng minh rằng một phương thức con sẽ loại bỏ tham số hoặc làm cho một tham số tùy chọn bắt buộc, không tương thích với phương thức mẹ.get_class() on the object.

Ví dụ #12 Lỗi gây tử vong khi phương pháp con xóa tham số

Fatal error: Declaration of Extend::foo() must be compatible with Base::foo(int $a = 5) in /in/evtlq on line 13
3

Ví dụ trên sẽ xuất ra:

Đầu ra của ví dụ trên trong Php 8 tương tự như:

Ví dụ #13 Lỗi nghiêm trọng khi phương thức con bắt buộc tham số tùy chọn bắt buộc

Fatal error: Declaration of Extend::foo() must be compatible with Base::foo(int $a = 5) in /in/evtlq on line 13
5 then
Fatal error: Declaration of Extend::foo() must be compatible with Base::foo(int $a = 5) in /in/evtlq on line 13
5
will be returned rather than an exception thrown. If the dereference is part of a chain, the rest of the chain is skipped.

Cảnh báois_null() check first, but more compact.

Đổi tên tham số của một phương thức trong một lớp con không phải là sự không tương thích của chữ ký. Tuy nhiên, điều này không được khuyến khích vì nó sẽ dẫn đến một lỗi thời gian chạy nếu các đối số được đặt tên được sử dụng.

Fatal error: Declaration of Extend::foo() must be compatible with Base::foo(int $a = 5) in /in/evtlq on line 13
7

Quy tắc tương thích chữ ký:

Khi ghi đè một phương thức, chữ ký của nó phải tương thích với phương thức mẹ. Mặt khác, một lỗi nghiêm trọng được phát ra, hoặc, trước Php 8.0.0, một lỗi cấp độ

bool(true)
bool(true)
bool(true)
0 được tạo ra. Chữ ký là tương thích nếu nó tôn trọng các quy tắc phương sai, tạo ra một tham số bắt buộc tùy chọn và nếu bất kỳ tham số mới nào là tùy chọn. Điều này được gọi là nguyên tắc thay thế Liskov, hoặc viết tắt là LSP. Các phương thức xây dựng và
bool(true)
bool(true)
bool(true)
1 được miễn trừ khỏi các quy tắc tương thích chữ ký này và do đó sẽ không phát ra lỗi nghiêm trọng trong trường hợp không khớp chữ ký.

Ví dụ #11 Phương pháp trẻ em tương thích

Các ví dụ sau đây chứng minh rằng một phương thức con sẽ loại bỏ tham số hoặc làm cho một tham số tùy chọn bắt buộc, không tương thích với phương thức mẹ.

Fatal error: Declaration of Extend::foo() must be compatible with Base::foo(int $a = 5) in /in/evtlq on line 13
8

Fatal error: Declaration of Extend::foo() must be compatible with Base::foo(int $a = 5) in /in/evtlq on line 13
9

Fatal error: Declaration of Extend::foo(int $a) must be compatible with Base::foo(int $a = 5) in /in/qJXVC on line 13
0

Fatal error: Declaration of Extend::foo(int $a) must be compatible with Base::foo(int $a = 5) in /in/qJXVC on line 13
1

Fatal error: Declaration of Extend::foo(int $a) must be compatible with Base::foo(int $a = 5) in /in/qJXVC on line 13
2

Fatal error: Declaration of Extend::foo(int $a) must be compatible with Base::foo(int $a = 5) in /in/qJXVC on line 13
3

Fatal error: Declaration of Extend::foo(int $a) must be compatible with Base::foo(int $a = 5) in /in/qJXVC on line 13
4

Fatal error: Declaration of Extend::foo(int $a) must be compatible with Base::foo(int $a = 5) in /in/qJXVC on line 13
5

Ví dụ #12 Lỗi gây tử vong khi phương pháp con xóa tham số

Đầu ra của ví dụ trên trong Php 8 tương tự như:

Fatal error: Declaration of Extend::foo(int $a) must be compatible with Base::foo(int $a = 5) in /in/qJXVC on line 13
6

Ví dụ #13 Lỗi nghiêm trọng khi phương thức con bắt buộc tham số tùy chọn bắt buộc

Cảnh báo

Fatal error: Declaration of Extend::foo(int $a) must be compatible with Base::foo(int $a = 5) in /in/qJXVC on line 13
7

Đổi tên tham số của một phương thức trong một lớp con không phải là sự không tương thích của chữ ký. Tuy nhiên, điều này không được khuyến khích vì nó sẽ dẫn đến một lỗi thời gian chạy nếu các đối số được đặt tên được sử dụng.

Ví dụ #Lỗi 14 Khi sử dụng các đối số và tham số được đặt tên được đổi tên trong lớp con

Fatal error: Declaration of Extend::foo(int $a) must be compatible with Base::foo(int $a = 5) in /in/qJXVC on line 13
8

Fatal error: Declaration of Extend::foo(int $a) must be compatible with Base::foo(int $a = 5) in /in/qJXVC on line 13
9

Fatal error: Uncaught Error: Unknown named parameter $foo in /in/XaaeN:14
Stack trace:
#0 {main}
  thrown in /in/XaaeN on line 14
0

Fatal error: Uncaught Error: Unknown named parameter $foo in /in/XaaeN:14
Stack trace:
#0 {main}
  thrown in /in/XaaeN on line 14
1

Fatal error: Uncaught Error: Unknown named parameter $foo in /in/XaaeN:14
Stack trace:
#0 {main}
  thrown in /in/XaaeN on line 14
2

Fatal error: Uncaught Error: Unknown named parameter $foo in /in/XaaeN:14
Stack trace:
#0 {main}
  thrown in /in/XaaeN on line 14
3

Fatal error: Uncaught Error: Unknown named parameter $foo in /in/XaaeN:14
Stack trace:
#0 {main}
  thrown in /in/XaaeN on line 14
4

Ví dụ trên sẽ xuất ra một cái gì đó tương tự như:

Từ khóa class cũng được sử dụng để giải quyết tên lớp. Để có được tên đủ điều kiện của lớp

Extending class
a default value
5 sử dụng
Extending class
a default value
6. Điều này đặc biệt hữu ích với các lớp theo tên.

Fatal error: Uncaught Error: Unknown named parameter $foo in /in/XaaeN:14
Stack trace:
#0 {main}
  thrown in /in/XaaeN on line 14
5

Ví dụ #15 Độ phân giải tên lớp

Các ví dụ sau đây chứng minh rằng một phương thức con sẽ loại bỏ tham số hoặc làm cho một tham số tùy chọn bắt buộc, không tương thích với phương thức mẹ.

Fatal error: Uncaught Error: Unknown named parameter $foo in /in/XaaeN:14
Stack trace:
#0 {main}
  thrown in /in/XaaeN on line 14
6

Fatal error: Uncaught Error: Unknown named parameter $foo in /in/XaaeN:14
Stack trace:
#0 {main}
  thrown in /in/XaaeN on line 14
7

Fatal error: Uncaught Error: Unknown named parameter $foo in /in/XaaeN:14
Stack trace:
#0 {main}
  thrown in /in/XaaeN on line 14
8

Fatal error: Uncaught Error: Unknown named parameter $foo in /in/XaaeN:14
Stack trace:
#0 {main}
  thrown in /in/XaaeN on line 14
9

class0

class1

Ví dụ #12 Lỗi gây tử vong khi phương pháp con xóa tham số

Đầu ra của ví dụ trên trong Php 8 tương tự như:

class2

class3

class4

class5

Fatal error: Declaration of Extend::foo(int $a) must be compatible with Base::foo(int $a = 5) in /in/qJXVC on line 13
5

Ví dụ #13 Lỗi nghiêm trọng khi phương thức con bắt buộc tham số tùy chọn bắt buộc

Từ khóa class cũng được sử dụng để giải quyết tên lớp. Để có được tên đủ điều kiện của lớp

Extending class
a default value
5 sử dụng
Extending class
a default value
6. Điều này đặc biệt hữu ích với các lớp theo tên.

class7

Ví dụ #15 Độ phân giải tên lớp

Ghi chú:

class8

class9

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
00

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
01

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
02

Fatal error: Declaration of Extend::foo(int $a) must be compatible with Base::foo(int $a = 5) in /in/qJXVC on line 13
5

Độ phân giải tên lớp sử dụng

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
9 là chuyển đổi thời gian biên dịch. Điều đó có nghĩa là tại thời điểm chuỗi tên lớp được tạo chưa có tự động tải đã xảy ra. Kết quả là, tên lớp được mở rộng ngay cả khi lớp không tồn tại. Không có lỗi được ban hành trong trường hợp đó.

Đầu ra của ví dụ trên trong Php 8 tương tự như:

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
04

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
05

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
06

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
07

Ví dụ #13 Lỗi nghiêm trọng khi phương thức con bắt buộc tham số tùy chọn bắt buộc

Các ví dụ sau đây chứng minh rằng một phương thức con sẽ loại bỏ tham số hoặc làm cho một tham số tùy chọn bắt buộc, không tương thích với phương thức mẹ.

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
08

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
09

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
10

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
11

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
12

Ví dụ #13 Lỗi nghiêm trọng khi phương thức con bắt buộc tham số tùy chọn bắt buộc

Cảnh báo

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
13

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
14

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
15

Fatal error: Declaration of Extend::foo(int $a) must be compatible with Base::foo(int $a = 5) in /in/qJXVC on line 13
5

Đổi tên tham số của một phương thức trong một lớp con không phải là sự không tương thích của chữ ký. Tuy nhiên, điều này không được khuyến khích vì nó sẽ dẫn đến một lỗi thời gian chạy nếu các đối số được đặt tên được sử dụng.

Ví dụ #Lỗi 14 Khi sử dụng các đối số và tham số được đặt tên được đổi tên trong lớp con

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
17

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
18

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
11

$this is defined (A)

Fatal error: Uncaught Error: Non-static method A::foo() cannot be called statically in %s :27
Stack trace:
#0 {main}
  thrown in %s  on line 27
20

Làm thế nào để bạn gọi một đối tượng lớp?

Gọi các phương thức của một đối tượng. Bạn cũng sử dụng một tham chiếu đối tượng để gọi phương thức của một đối tượng. Bạn nối tên đơn giản của phương thức vào tham chiếu đối tượng, với toán tử chấm can thiệp (.). Ngoài ra, bạn cung cấp, trong vòng dấu ngoặc đơn, bất kỳ đối số nào cho phương thức.use an object reference to invoke an object's method. You append the method's simple name to the object reference, with an intervening dot operator (.). Also, you provide, within enclosing parentheses, any arguments to the method.

__ cuộc gọi () trong PHP là gì?

Phương thức __call () được gọi tự động khi phương thức không tồn tại hoặc phương thức không thể truy cập được gọi.Sau đây cho thấy cú pháp của phương thức __call (): public __call (chuỗi $ name, mảng $ đối số): hỗn hợp.Ngôn ngữ mã: PHP (PHP)invoked automatically when a non-existing method or inaccessible method is called. The following shows the syntax of the __call() method: public __call ( string $name , array $arguments ) : mixed. Code language: PHP (php)

Làm thế nào để bạn gọi một đối tượng trong PHP?

Để gọi một phương thức trên một đối tượng, bạn chỉ cần gọi tên đối tượng theo sau là "->" và sau đó gọi phương thức.Vì đó là một tuyên bố, bạn đóng nó bằng một dấu chấm phẩy.Khi bạn đang xử lý các đối tượng trong PHP, "->" hầu như luôn được sử dụng để truy cập đối tượng đó, cho dù đó là thuộc tính hay gọi phương thức.call the object name followed by "->" and then call the method. Since it's a statement, you close it with a semicolon. When you are dealing with objects in PHP, the "->" is almost always used to access that object, whether it's a property or to call a method.

Làm thế nào để bạn gọi một hàm tạo lớp trong PHP?

Để gọi hàm tạo của lớp cha từ hàm tạo của lớp con, bạn sử dụng cú pháp của cha mẹ :: __ Construct (arguments).Cú pháp để gọi hàm tạo cha mẹ giống như một phương thức thông thường.parent::__construct(arguments) syntax. The syntax for calling the parent constructor is the same as a regular method.