Lịch quốc tế. Hàm before[] là một hàm sẵn có trong PHP trả về True nếu thời gian hiện tại của đối tượng trước thời gian của đối tượng đã truyền
cú pháp
- Phong cách hướng đối tượng.
bool IntlCalendar::before[ IntlCalendar $other ]
- phong cách thủ tục.
bool intlcal_before[ IntlCalendar $cal, IntlCalendar $other ]
Thông số
- $cal. Tham số này chứa tài nguyên IntlCalendar
- $khác. Tham số này giữ lịch có thời gian được kiểm tra so với thời gian của đối tượng chính
Giá trị trả về. Hàm này trả về TRUE nếu thời gian hiện tại của đối tượng trước thời gian của đối tượng đã truyền
Dấu và ngay trước tên hàm sẽ trả về một tham chiếu đến biến thay vì trả về giá trị của nó. Trả về theo tham chiếu rất hữu ích khi bạn muốn sử dụng một hàm để tìm biến mà một tham chiếu sẽ bị ràng buộc. Không sử dụng return-by-reference để tăng hiệu suất. Trong PHP 4, các đối tượng được gán theo giá trị, giống như bất kỳ giá trị nào khác. Điều này rất phản trực giác và ngược lại với cách hoạt động của hầu hết các ngôn ngữ khác
Ví dụ. Ví dụ này minh họa khái niệm đằng sau việc đặt dấu và để bắt đầu một hàm PHP
Thuộc tính của đối tượng được trả về bởi hàm getValue[] sẽ được đặt thay vì bản sao như khi không sử dụng cú pháp tham chiếu. Không giống như truyền tham số, ở đây bạn phải sử dụng dấu và ở cả hai vị trí để biểu thị rằng bạn muốn trả về theo tham chiếu chứ không phải bản sao và để biểu thị rằng liên kết tham chiếu, thay vì gán thông thường, nên được thực hiện cho $myValue
Trong PHP, dấu và [&] được đặt trước tên hàm để trả về tham chiếu đến biến thay vì trả về giá trị. Để trả về theo tham chiếu rất thuận tiện cho việc sử dụng một hàm để phát hiện một biến mà một tham chiếu được liên kết với
Không nên sử dụng trả về theo tham chiếu để tăng hiệu suất
Để hiểu rõ hơn, hãy xem xét một ví dụ chi tiết về việc sử dụng dấu và để bắt đầu một hàm PHP
Thay vì sao chép, cần đặt thuộc tính của đối tượng được trả về bởi getValue[]
Ngược lại với việc truyền tham số, ở đây, bạn nên đặt dấu và ở cả hai vị trí để chỉ định rằng bạn muốn trả về bằng tham chiếu
Ví dụ sẽ như sau
Đầu ra của đoạn mã trên sẽ là
2
Hai biến có thể được gọi đến cùng một nội dung với sự trợ giúp của các tham chiếu
Nói cách khác, một biến chỉ định nội dung của nó thay vì trở thành nội dung đó
Truyền theo tham chiếu tạo cơ hội cho hai biến chỉ định cùng một nội dung dưới các tên riêng biệt. Để được tham chiếu, dấu và phải được đặt trước biến
Kính thưa tất cả,Tôi đang tìm kiếm các hướng dẫn lập trình PHP OO nâng cao và
tìm thấy www. afascripts. com.
Họ trình bày các hướng dẫn rất hay, nhưng có một điều làm tôi bối rối. trong một số
mã có dấu gạch chéo ngược trước tên hàm, e. g.
\spl_autoload_register[array[$autoLoader, 'load']];
\class_exists[$classname]. \interface_exists[$classname]]{
if [\file_exists[$file]]{
[có một cái nhìn tại]
Dấu gạch chéo ngược trước tên hàm làm gì?
Trân trọng,
George
Các phương thức ma thuật là các phương thức đặc biệt ghi đè hành động mặc định của PHP khi một số hành động nhất định được thực hiện trên một đối tượng
thận trọng
Tất cả các tên phương thức bắt đầu bằng
22 đều được bảo lưu bởi PHP. Do đó, không nên sử dụng các tên phương thức như vậy trừ khi ghi đè hành vi của PHP
Các tên phương thức sau đây được coi là ma thuật. , , , , , , , , , , , , , , , , và
Cảnh báo
Nếu các khai báo kiểu được sử dụng trong định nghĩa của một phương thức ma thuật, thì chúng phải giống với chữ ký được mô tả trong tài liệu này. Nếu không, một lỗi nghiêm trọng được phát ra. Trước PHP 8. 0. 0, không có chẩn đoán nào được phát ra. Tuy nhiên, và không được khai báo kiểu trả về;
serialize[] kiểm tra xem lớp có chức năng với tên ma thuật không. Nếu vậy, chức năng đó được thực thi trước bất kỳ tuần tự hóa nào. Nó có thể dọn sạch đối tượng và được cho là trả về một mảng có tên của tất cả các biến của đối tượng đó sẽ được tuần tự hóa. Nếu phương thức không trả về bất cứ thứ gì thì
23 được đánh số thứ tự và
24 được cấp
Ghi chú
Không thể trả về tên của các thuộc tính riêng trong các lớp cha. Làm điều này sẽ dẫn đến lỗi cấp độ
24. sử dụng thay thế
Mục đích sử dụng của là chuyển giao dữ liệu đang chờ xử lý hoặc thực hiện các tác vụ dọn dẹp tương tự. Ngoài ra, chức năng này rất hữu ích nếu một đối tượng rất lớn không cần phải lưu hoàn toàn
Ngược lại, unserialize[] kiểm tra sự hiện diện của một hàm có tên ma thuật. Nếu có, chức năng này có thể tái tạo lại bất kỳ tài nguyên nào mà đối tượng có thể có
Mục đích sử dụng của là để thiết lập lại bất kỳ kết nối cơ sở dữ liệu nào có thể đã bị mất trong quá trình tuần tự hóa và thực hiện các tác vụ khởi tạo lại khác
Ví dụ #1 Ngủ và thức dậy
26
27
28
string[60] "A::__set_state[array[ 'var1' => 5, 'var2' => 'foo', ]]" object[A]#2 [2] { ["var1"]=> int[5] ["var2"]=> string[3] "foo" }0
string[60] "A::__set_state[array[ 'var1' => 5, 'var2' => 'foo', ]]" object[A]#2 [2] { ["var1"]=> int[5] ["var2"]=> string[3] "foo" }1
công khai __serialize[]. mảng
công khai __unserialize[mảng
string[60] "A::__set_state[array[ 'var1' => 5, 'var2' => 'foo', ]]" object[A]#2 [2] { ["var1"]=> int[5] ["var2"]=> string[3] "foo" }2]. khoảng trống
serialize[] kiểm tra xem lớp có chức năng với tên ma thuật không. Nếu vậy, chức năng đó được thực thi trước bất kỳ tuần tự hóa nào. Nó phải xây dựng và trả về một mảng kết hợp gồm các cặp khóa/giá trị đại diện cho dạng tuần tự hóa của đối tượng. Nếu không có mảng nào được trả về, TypeError sẽ bị ném
Ghi chú
Nếu cả hai và được định nghĩa trong cùng một đối tượng, only sẽ được gọi. sẽ bị bỏ qua. Nếu đối tượng triển khai giao diện Nối tiếp, phương thức
string[60] "A::__set_state[array[ 'var1' => 5, 'var2' => 'foo', ]]" object[A]#2 [2] { ["var1"]=> int[5] ["var2"]=> string[3] "foo" }3 của giao diện sẽ bị bỏ qua và được sử dụng thay thế
Mục đích sử dụng của là để xác định một biểu diễn tùy ý thân thiện với tuần tự hóa của đối tượng. Các phần tử của mảng có thể tương ứng với thuộc tính của đối tượng nhưng không bắt buộc
Ngược lại, unserialize[] kiểm tra sự hiện diện của một hàm có tên ma thuật. Nếu có, chức năng này sẽ được thông qua mảng khôi phục đã được trả về từ. Sau đó, nó có thể khôi phục các thuộc tính của đối tượng từ mảng đó khi thích hợp
Ghi chú
Nếu cả hai và được định nghĩa trong cùng một đối tượng, only sẽ được gọi. sẽ bị bỏ qua
Ghi chú
Tính năng này có sẵn kể từ PHP 7. 4. 0
Ví dụ #2 Tuần tự hóa và hủy tuần tự hóa
26
27
28
string[60] "A::__set_state[array[ 'var1' => 5, 'var2' => 'foo', ]]" object[A]#2 [2] { ["var1"]=> int[5] ["var2"]=> string[3] "foo" }7
string[60] "A::__set_state[array[ 'var1' => 5, 'var2' => 'foo', ]]" object[A]#2 [2] { ["var1"]=> int[5] ["var2"]=> string[3] "foo" }8
string[60] "A::__set_state[array[ 'var1' => 5, 'var2' => 'foo', ]]" object[A]#2 [2] { ["var1"]=> int[5] ["var2"]=> string[3] "foo" }9
công khai __toString[]. chuỗi
Phương thức này cho phép một lớp quyết định nó sẽ phản ứng như thế nào khi nó được coi như một chuỗi. Ví dụ, những gì
bool intlcal_before[ IntlCalendar $cal, IntlCalendar $other ]00 sẽ in
Cảnh báo
Kể từ PHP 8. 0. 0, giá trị trả về tuân theo ngữ nghĩa kiểu PHP tiêu chuẩn, nghĩa là nó sẽ bị ép buộc thành một chuỗi nếu có thể và nếu bị tắt
Kể từ PHP 8. 0. 0, bất kỳ lớp nào chứa một phương thức cũng sẽ triển khai ngầm giao diện Stringable và do đó sẽ vượt qua kiểm tra kiểu cho giao diện đó. Nên triển khai giao diện một cách rõ ràng
Trong PHP7. 4, giá trị được trả về phải là một chuỗi, nếu không sẽ xảy ra Lỗi
Trước PHP 7. 4. 0, giá trị được trả về phải là một chuỗi, nếu không thì một lỗi nghiêm trọng
bool intlcal_before[ IntlCalendar $cal, IntlCalendar $other ]01 được phát ra
Cảnh báo
Không thể đưa ra một ngoại lệ từ bên trong một phương thức trước PHP 7. 4. 0. Làm như vậy sẽ dẫn đến một lỗi nghiêm trọng
Ví dụ #3 Ví dụ đơn giản
bool intlcal_before[ IntlCalendar $cal, IntlCalendar $other ]02
bool intlcal_before[ IntlCalendar $cal, IntlCalendar $other ]03
bool intlcal_before[ IntlCalendar $cal, IntlCalendar $other ]04
bool intlcal_before[ IntlCalendar $cal, IntlCalendar $other ]05
Ví dụ trên sẽ xuất ra
__gọi[
bool intlcal_before[ IntlCalendar $cal, IntlCalendar $other ]06].
Phương thức được gọi khi tập lệnh cố gọi một đối tượng dưới dạng hàm
Ví dụ #4 Sử dụng
bool intlcal_before[ IntlCalendar $cal, IntlCalendar $other ]07
Ví dụ trên sẽ xuất ra
Ví dụ #5 Sử dụng
bool intlcal_before[ IntlCalendar $cal, IntlCalendar $other ]08
bool intlcal_before[ IntlCalendar $cal, IntlCalendar $other ]09
220
221
222
223
Ví dụ trên sẽ xuất ra
20
tĩnh __set_state [mảng
224]. vật
Phương thức tĩnh này được gọi cho các lớp được xuất bởi var_export[]
Tham số duy nhất của phương thức này là một mảng chứa các thuộc tính được xuất ở dạng
225
Ví dụ #6 Sử dụng
226
227
228
229
Ví dụ trên sẽ xuất ra
string[60] "A::__set_state[array[ 'var1' => 5, 'var2' => 'foo', ]]" object[A]#2 [2] { ["var1"]=> int[5] ["var2"]=> string[3] "foo" }
Ghi chú. Khi xuất một đối tượng, var_export[] không kiểm tra xem lớp của đối tượng có được triển khai hay không, do đó, việc nhập lại các đối tượng sẽ dẫn đến một ngoại lệ Lỗi, nếu __set_state[] không được triển khai. Đặc biệt, điều này ảnh hưởng đến một số lớp nội bộ. Lập trình viên có trách nhiệm xác minh rằng chỉ các đối tượng sẽ được nhập lại, có lớp thực hiện __set_state[]
Phương thức này được gọi bởi var_dump[] khi kết xuất một đối tượng để lấy các thuộc tính sẽ được hiển thị. Nếu phương thức không được xác định trên một đối tượng, thì tất cả các thuộc tính công khai, được bảo vệ và riêng tư sẽ được hiển thị