Sự phát triển của PHP từ 5.6 đến 8.0
https://viblo.asia/p/su-phat-trien-cua-php-tu-56-den-80-yMnKMvbmZ7P
Last updated
Was this helpful?
https://viblo.asia/p/su-phat-trien-cua-php-tu-56-den-80-yMnKMvbmZ7P
Last updated
Was this helpful?
Bài đăng này đã không được cập nhật trong 2 năm
Một đánh giá cô đọng về các thay đổi trong PHP v7.x trong vòng dưới 15 phút
Khi phiên bản PHP 7.3 được phát hành, tôi quyết định xem xét chi tiết về phát triển PHP: điều gì đang được phát triển và hướng nào để hiểu rõ hơn tiềm năng mới và tối ưu hóa của ngôn ngữ lập trình phổ biến rộng rãi này.
Sau khi tìm kiếm một danh sách các tính năng cô đọng mà PHP đã triển khai trong quá trình phát triển PHP v7.x, tôi đã quyết định tự mình biên dịch danh sách này - một cách bắt kịp công nghệ mà tôi tin rằng ai đó cũng có thể thấy nó hữu ích.
Chúng ta sẽ bắt đầu với PHP 5.6 như một đường cơ sở và sẽ xem xét những gì đã được thêm vào, thay đổi. Tôi cũng đã thêm các liên kết đến tài liệu chính thức cho từng điều được đề cập, vì vậy nếu bạn quan tâm đến việc đọc sâu hơn - hãy tự nhiên.
Một anonymous class có thể được sử dụng trên một class được đặt tên:
Khi class không cần phải được ghi lại.
Khi class chỉ được sử dụng một lần trong khi thực thi.
Hàm chia số nguyên -- cách an toàn để chia (thậm chí cho 0). Nó trả về phép chia số nguyên của toán hạng thứ nhất cho toán hạng thứ hai. Nếu số chia (toán hạng thứ hai) bằng 0, nó sẽ ném E_WARNING
và trả về FALSE
.
Đã thêm mới toán tử hợp nhất null -- là ??
Đã thêm mới toán tử space ship (<=>)
Được sử dụng để tối ưu hóa và đơn giản hóa các phép so sánh.
Đây chỉ là bước đầu để đạt được ngôn ngữ lập trình mạnh mẽ hơn trong PHP - v0.5.
Cú pháp mới sau đây được cho phép trong phần thân của các hàm generator:
Cải thiện hiệu suất
PHP7 nhanh gấp đôi so với PHP5.6
Sử dụng bộ nhớ giảm đáng kể
Như bạn có thể thấy từ các biểu đồ, PHP 7.0 là một cải tiến lớn về hiệu suất và việc sử dụng bộ nhớ. Đối với trang có các truy vấn cơ sở dữ liệu, phiên bản 7.0.0 nhanh hơn 3 lần so với 5.6 với opcache được bật và nhanh hơn 2,7 lần mà không cần opcache! Về mặt sử dụng bộ nhớ, sự khác biệt cũng rất đáng kể!
Tái cấu trúc các exception class để có một naming scheme không trực quan và sẽ dẫn đến ít nhầm lẫn hơn, đặc biệt là đối với người dùng mới hơn.
Errors
và Exception
bây giờ được implement Throwable
Đây là hệ thống cấp bậc của Throwable
Chú ý: bạn chỉ có thể implement Throwable
thông qua Error
và Exception
.
Unicode Codepoint Escape Syntax — “\u{xxxxx}”
Với những từ globally reserved nay đã trở thành semi-reserved:
Mức hỗ trợ cho functions dirname()
Không giống như các kiểu trả về khác được thi hành khi hàm được gọi, loại này được kiểm tra tại thời gian biên dịch, điều đó có nghĩa là một lỗi được tạo ra mà không cần gọi hàm.
Một hàm có kiểu trả về là void
hoặc hàm void
, có thể trả về ngầm hoặc có câu lệnh return mà không có giá trị:
Thông thường, một hàm chấp nhận hoặc trả về một array
hoặc một object implementing Traversable
sẽ được sử dụng với foreach
. Tuy nhiên, vì mảng là kiểu nguyên thủy và Traversable
là một interface, hiện tại không có cách nào để sử dụng khai báo kiểu trên tham số hoặc kiểu trả về để chỉ ra rằng giá trị có thể lặp lại được.
iterable
cũng có thể được sử dụng như một kiểu trả về để chỉ ra một hàm sẽ trả về một giá trị lặp. Nếu giá trị được trả về không phải là một mảng hoặc instance của Traversable
, TypeError
sẽ được throw.
Các tham số được khai báo với iterable
có thể sử dụng null
hoặc một mảng làm giá trị mặc định.
Cú pháp dấu ngoặc vuông cho phép destructuring assignment mảng
Cú pháp dấu ngoặc vuông cho danh list()
Catching Multiple Exception Types
Gọi count()
trên một scalar hoặc object không implement Countable interface trả về 1 (phi logic).
Trong phiên bản này đã thêm một cảnh báo khi gọi count()
với tham số là scalar, null hoặc một object không implement Countable
.
Cú pháp dấu phảy được sử dụng trong namespace
Các hàm password_ *
hiện có cung cấp interface đơn giản để băm mật khẩu. RFC này đề xuất triển khai Argon2i (v1.3) trong các hàm password_ *
để sử dụng thay thế an toàn cho bcrypt
.
Debugging PDO Prepared Statement Emulation
FFI là một trong những tính năng giúp Python và LuaJIT rất hữu ích cho việc tạo mẫu nhanh. Nó cho phép gọi các hàm C và sử dụng các kiểu dữ liệu C từ ngôn ngữ kịch bản thuần túy và do đó phát triển "system code" hiệu quả hơn. Đối với PHP, FFI mở ra một cách để viết các phần mở rộng và ràng buộc PHP vào các thư viện C trong PHP thuần.
Null Coalescing Assignment Operator
PHP đã sử dụng opcode caches từ lâu (APC, Turck MMCache, Zend OpCache). Họ đạt được hiệu suất tăng đáng kể bằng cách GẦN NHƯ loại bỏ hoàn toàn overhead của biên dịch lại PHP code. Preloading sẽ được kiểm soát chỉ bằng một chỉ thị php.ini
mới - opcache.preload. Sử dụng chỉ thị này, chúng ta sẽ chỉ định một file PHP - sẽ thực hiện nhiệm vụ tải trước. Sau khi tải, file này sau đó được thực thi đầy đủ - và có thể tải trước các file khác, bằng cách including chúng hoặc bằng cách sử dụng hàm opcache_compile_file()
.
Điều này sẽ làm cho hash extension (`ext / hash`) luôn có sẵn, tương tự như `date`. Phần hash extension cung cấp một tiện ích rất phong phú với nhiều thuật toán băm cực kỳ hữu ích trong các ứng dụng hiện đại, không chỉ trong code người dùng mà còn rất nhiều trong nội bộ.
Nói ngắn gọn. Khi bạn khởi động một chương trình PHP, Zend Engine sẽ phân tích code thành một cây cú pháp trừu tượng (AST) và dịch nó sang opcodes. Các opcodes là các đơn vị thực thi cho Máy ảo Zend (Zend VM). Opcode là mức độ khá thấp, do đó dịch code sang máy nhanh hơn nhiều so với code PHP gốc. PHP có một phần mở rộng có tên OPcache trong lõi, để lưu trữ các opcodes này.
“JIT” is a technique that will compile parts of the code at runtime, so that the compiled version can be used instead.
Đây là một trong những chiến lược tối ưu hóa PHP cuối cùng và lớn nhất vẫn còn trên bàn. Các PHP engineers đang tìm kiếm để xem cách tiếp cận mới này có thể vượt qua các ứng dụng của họ. Thực sự quan tâm đến điều này.
Nhất quán loại errors cho internal function
Làm cho các API phân tích tham số nội bộ luôn tạo ra TypeError
nếu parameter parsing không thành công. Cần lưu ý rằng điều này cũng bao gồm ArgumentCountError
(con của TypeError
) cho các trường hợp có quá ít/nhiều đối số được thông qua.
Tôi đã soạn một bài test đơn giản để giúp dễ dàng so sánh hiệu suất của các phiên bản PHP khác nhau (sử dụng Docker). Điều này thậm chí sẽ cho phép dễ dàng kiểm tra hiệu năng của các phiên bản PHP mới chỉ bằng cách thêm tên container mới.
Chạy trên Macbook pro, 2,5 GHz Intel Core i7.
Nếu muốn tự kiểm tra, bạn có thể tìm source code trong repository này.
PHP 7.0.0 là một cột mốc quan trọng với hiệu suất được cải thiện đáng kể và sử dụng bộ nhớ thấp hơn nhưng các PHP maintainers chỉ đơn giản là hết ý tưởng để cải thiện nó. Một trong những điểm còn lại là biên dịch JIT (Just in time). Và nó đi kèm với PHP 8.0.
Trong suốt các phiên bản PHP 7.x, có một path có thể nhìn thấy được nhắc tới nhiều hơn (và khách quan hơn một chút) và ngôn ngữ lập trình hiện đại. Tuy nhiên, PHP thích áp dụng các tính năng hữu ích và gọn gàng từ các ngôn ngữ lập trình khác.
Chúng ta sẽ sớm thấy một số tính năng hay hơn, như:
Với những điều này, PHP developers sẽ tham gia nhóm những người áp dụng ngôn ngữ hiện đại. Không có ngôn ngữ nào là hoàn hảo, nhưng PHP đang mở đường cho tương lai.
Để rút ngắn hơn nữa, tôi đã chọn hầu hết các thay đổi quan trọng đối với ý kiến cá nhân của mình với phiên bản mới nhất của PHP 7.3. Chúng đây rồi:
References:
https://wiki.php.net/rfc https://www.cloudways.com/blog/php-5-6-vs-php-7-symfony-benchmarks/ https://servebolt.com/articles/wordpress-5-0-php-7-2-vs-php-7-3-performance-and-speed-benchmark/
The head illustration was made by Badoo team for Badoo Tech blog
https://tech.badoo.com/ru/article/511/php-8-chego-zhdat-pismo/
Nguồn: https://medium.com/@meskis/evolution-of-php-v5-6-to-v8-0-c3514ebb7f28
Đã thêm khả năng trả về các type ngoài scalar - các class bao gồm cả thừa kế. Vẫn bằng cách nào đó hoàn toàn bỏ lỡ khả năng làm cho nó tùy chọn (được giới thiệu trong v7.1 ).
Tôi thực sự thích phần tổng hợp hiệu năng trực quan từ servbolt.com của tất cả các phiên bản chính từ 5.6 trở lên. Xem kết quả trong các bảng dưới đây.