PHP 5.4 の新機能と非推奨関数の概要
PHP 5.4 の新機能と非推奨の関数の概要の概要:
1. PHP5.4の新機能
1. メモリとパフォーマンスの向上: 大規模な PHP アプリケーションでのメモリの 20 ~ 50% の節約。さまざまな最適化によりパフォーマンスが 10 ~ 30% 向上します
2. サポート特性
3. 配列構文が簡略化され、短い配列を定義できます
4. 関数配列の逆参照、配列の逆参照をサポート、
5. インスタンスメソッド呼び出し
6. クロージャーバインディング
7. オブジェクトは関数です
8. 組み込み Web サーバー (CLI)
9. ネイティブセッションハンドラーインターフェース
10. JsonSerializable インターフェース
11. バイナリ表現
12. エラーメッセージの改善
13. 配列から文字列への変換通知
14. 関数型ヒントの強化 (Callable typehint)
15. 時間統計の強化、高精度タイマー
16. アップロード進行状況バーアップロード進行状況
17. PHP 5.4 の Zend シグナル
18. PHP 5.4 では、Arnaud による三項式の最適化スキームが導入されました。
1) 非推奨:allow_call_time_pass_reference、define_syslog_variables、highlight.bg、register_globals、register_long_arrays、magic_quotes、safe_mode、zend.ze1_compatibility_mode、session.bug_compat42、session.bug_compat_warn、および y2k_compliance。
2) PHP の Break および continue 変数構文はサポートされなくなりました
3) mysqlnd このバンドルされた MySQL ネイティブ ドライバー ライブラリは、コンパイル時に ./configure によって明示的にオーバーライドされない限り、MySQL と通信するさまざまな拡張機能にデフォルトで使用されるようになりました。
5.4 にアップグレードすると表示される主な機能は次のとおりです:
1. メモリとパフォーマンスの向上
多くの内部構造が小さくなったり、完全に消えたりした結果、大規模な PHP アプリケーションでは 20 ~ 50% のメモリが節約されます。さまざまな共通コード パスのインライン化、JIT への $GLOBALS の追加、「@」演算子の高速化、ランタイム クラス/関数/定数キャッシュの追加、ランタイムなどのさまざまな最適化により、パフォーマンスが 10 ~ 30% 向上します (主にコードの動作に応じて)。文字列定数が保持されるようになり、事前計算されたハッシュを介した定数へのアクセスが高速になり、空の配列が高速になり使用メモリが減り、unserialize() と FastCGI リクエストの処理が高速になり、コード全体のメモリとパフォーマンスの調整が強化されました。
たとえば、いくつかの初期テストでは、5.4 では Zend Framework が 21% 高速に動作し、使用するメモリが 23% 少ないことが示されています。一方、Drupal は、50% 少ないメモリ使用で、約 7% 高速に動作します。
2. サポート特性
トレイトはおそらく PHP 5.4 で最も話題になっている機能です。トレイトはコンパイラ支援のコピーアンドペーストと考えてください。トレイトも Scala の機能です。他の言語ではそれらを「ミックスイン」と呼ぶ場合があります。または、これらの言語では名前をまったく付けない場合もありますが、インターフェイスにそのメソッドの実際の実装を含めることを可能にする拡張インターフェイス メカニズムを備えています。
ミックスインとは対照的に、PHP のトレイトには、複数のトレイトが同じメソッドを実装する場合に備えた明示的な競合解決メカニズムが含まれています。
trait Singleton { public static function getInstance() { ... } } class A { use Singleton; // ... } class B extends ArrayObject { use Singleton; // ... } // Singleton method is now available for both classes A::getInstance(); B::getInstance();
競合解決構文、メソッドの優先順位、可視性、特性の定数とプロパティのサポートなど、その他の例については、php.net/traits を参照してください。さらに、概念理論について詳しく知りたい場合は、Nathan Schärli の論文「Traits: Compositional Classes in Behavioral Building Blocks」を読むことができます。
3. 簡略化された配列構文
シンプルだが非常に人気のある新しい構文:
$a = [1, 2, 3]; $b = ['foo' => 'orange', 'bar' => 'apple'];
つまり、配列を定義するために「array」キーワードを使用する必要がなくなりました。
4. 関数配列の逆参照、配列の逆参照をサポートします。
1) 別の新しい共通構文が追加されました。配列を返す関数呼び出しを直接逆参照できるようになりました:
function fruits() { return ['apple', 'banana', 'orange']; } echo fruits()[0]; // Outputs: apple
2) 配列の逆参照を使用すると、以前の書き込み方法は必要なくなります。
<?php list($name,) = explode(",", "Laruence, male"); ?>
代わりに:
$name =explode(",", "b, x")[0];
さらに、配列の参照解除は再代入ステートメントの左辺値にも現れることができます。これは、理論的には次のように記述できることを意味します:
explode(",", "test1, test2")[3] = "phper";
5. インスタンスメソッド呼び出し
関数配列の参照解除に関連して、オブジェクトのインスタンス化メソッドを呼び出すことができるようになりました。以前のバージョンと同様に、もちろんメソッド呼び出しを連鎖させることができるため、次のようなコードを記述できるようになりました:
class foo { public $x = 1; public function getX() { return $this->x; } public function setX($val) { $this->x = $val; return $this; } } $X = (new foo)->setX(20)->getX(); echo $X; // 20
ただし、インスタンス化されたオブジェクトは破棄される可能性があるため、コンストラクターが何か有用な処理をしない限り、ここでは代わりに静的メソッド呼び出しを使用する必要があります。これを圧縮配列構文と関数配列の参照解除と組み合わせると、非常に複雑なコードを作成できます。
class foo extends ArrayObject { public function __construct($arr) { parent::__construct($arr); } } echo (new foo( [1, [4, 5], 3] ))[1][0];
これを見て、出力が何であるかわかりますか?ここでは、配列を返すだけのコンストラクターに 2D 配列を渡します。次に、2 番目の次元の最初の要素を選択します。これにより、「4」が出力されます。
6. クロージャーバインディング
クラス インスタンス
闭包是在 PHP 5.3 中引入的,但在 5.4 中我们改进了闭包与对象的交互方式。例如:
class Foo { private $prop; function __construct($prop) { $this->prop = $prop; } public function getPrinter() { return function() { echo ucfirst($this->prop); }; } } $a = new Foo('bar');; $func = $a->getPrinter(); $func(); // Outputs: Bar
注意闭包访问 $this->prop 这一私有属性。默认情况下,PHP 中的闭包使用预绑定 — 这意味着闭包内的变量具有定义闭包时所具有的值。可以使用引用将其转换为后绑定。但是,也可以重新绑定闭包:
$a = new Foo('bar'); $b = new Foo('pickle'); $func = $a->getPrinter(); $func(); // Outputs: Bar $func = $func->bindTo($b); $func(); // Outputs: Pickle
在此,我们将闭包从 $a 实例重新绑定到 $b 中的实例。如果您不希望闭包随时访问对象实例,可以将闭包声明为静态:
class Foo { private $prop; function __construct($prop) { $this->prop = $prop; } public function getPrinter() { return static function() { echo ucfirst($this->prop); }; } } $a = new Foo('bar');; $func = $a->getPrinter(); $func(); // Fatal error: Using $this when not in object context
7. 对象即函数
有一种新的神奇方法,名为“__invoke”,其用法如下:
class MoneyObject { private $value; function __construct($val) { $this->value = $val; } function __invoke() { return sprintf('$%.2f',$this->value); } } $Money = new MoneyObject(11.02/5*13); echo $Money(); // Outputs: $28.65
8. 内置 Web 服务器 (CLI)
CLI 服务器是一种小型 Web 服务器实现,可以从命令行运行:
% php -S localhost:8000 PHP 5.4.0 Development Server started at Sun Mar 11 13:27:09 2012 Listening on localhost:8080 Document root is /home/rasmus Press Ctrl-C to quit.
CLI 服务器不适合用作生产 Web 服务器;我们将使用它运行一些 PHP 回归测试,其他单元测试机制也可使用它,并且 IDE 也可能使用它。它确实具有一些很有用的特性,用于从命令行进行日常代码调试。默认情况下,它使用当前目录作为 DocumentRoot;它也处理静态文件请求。默认目录索引文件为“index.php”,因此您可以在满含 .php、.css、.jpg 等文件的目录中激活它,它自己就可以运行。对于可能使用 mod_rewrite 将所有请求发送到前端控制器或路由器的更复杂应用程序,您可以将此路由器与一个简单的小脚本包装在一起,并启动 CLI 服务器,如下所示:
% php -S localhost:8080 /path/to/router.php PHP 5.4.0 Development Server started at Sun Mar 11 13:28:01 2012 Listening on localhost:8080 Document root is /tmp/web Press Ctrl-C to quit.
router.php 脚本可能如下所示:
<?php if (preg_match('!\.php$!', $_SERVER["REQUEST_URI"])) { require basename($_SERVER["REQUEST_URI"]); } else if (strpos($_SERVER["REQUEST_URI"], '.')) { return false; // serve the requested file as-is. } else { Framework::Router($_SERVER["REQUEST_URI"]); }
此包装器加载直接 .php 请求,将包含“.”的任何其他请求传递到静态文件处理程序,其他所有内容都传递到框架的路由器。您可以如此直接从命令行运行 Drupal 和 Symphony。
9. 原生会话处理程序接口
这是一个小而方便的特性,现在可以用它实现会话处理程序接口。现在,您可以仅将会话处理对象的实例传递给 session_set_save_handler(),而不必传递给它六个比较麻烦的函数:
SessionHandler implements SessionHandlerInterface { public int close ( void ) public int destroy ( string $sessionid ) public int gc ( int $maxlifetime ) public int open ( string $save_path , string $sessionid ) public string read ( string $sessionid ) public int write ( string $sessionid , string $sessiondata ) } session_set_save_handler(new MySessionHandler);
10. JsonSerializable 接口
现在,您可以通过实现 JsonSerializable 接口来控制有人尝试使用 json_encode() 对您的对象进行编码时所发生的情况:
class Foo implements JsonSerializable { private $data = 'Bar'; public function jsonSerialize() { return array('data'=>$this->data); } } echo json_encode(new Foo); // Outputs: {"data":"Bar"}
11. 二进制表示法
为了与 PHP 的原生十六进制和八进制支持协调一致,现在也支持二进制表示法:采用“0b”前缀标识二进制数
$mask = 0b010101;
12. 改进了错误消息
错误消息稍有改进。
改进前:
% php -r 'class abc foo' Parse error: syntax error, unexpected T_STRING, expecting '{' in Command line code on line 1
改进后:
% php -r 'class abc foo' Parse error: syntax error, unexpected 'foo' (T_STRING), expecting '{' in Command line code on line
改进可能不十分明显,但区别是现在已在错误消息中显示偏移标记“foo”的值。
13. 数组到字符串转换通知
如果您一直使用 PHP,则可能以随机出现在页面中“Array”一词结束编程,因为您尝试直接输出数组。每当将数组直接转换为字符串时,都很有可能出现错误,现在有了一个针对这一情况的通知:
$a = [1,2,3]; echo $a;
注意:数组到字符串转换在 example.php onlLine 2 中
14. 函数类型提示的增强,(Callable typehint)
由于php是弱类型的语言,因此在php 5.0后,引入了函数类型提示的功能,支持对象和数组,其含义为对于传入函数中的参数都进行类型检查,举个例子,有如下的类:
class bar { } function foo(bar $foo) { }
其中函数foo中的参数规定了传入的参数必须为bar类的实例,否则系统会判断出错。同样对于数组来说,也可以进行判断,比如:
function foo(array $foo) { } foo(array ( 1, 2, 3 )); // 正确,因为传入的是数组 foo(123); // 不正确,传入的不是数组 function my_function(callable $x) { return $x(); }
而在php 5.4中,则支持对callable类型的支持。在以前, 我们如果希望一个函数接受一个回调函数作为参数, 那需要做很多额外的工作来检查是否是可调用的正确的回调函数,例子如下:
function foo(callable $callback) { }
则:
foo("false"); //错误,因为false不是callable类型 foo("printf"); //正确 foo(function () { }); //正确 class A { static function show() { } } foo(array ( "A", "show" )); //正确
遗憾的是,PHP 5.4中,依然不支持对基本类型如字符,整形等的类型提示。
15. 对时间统计的增强,高精度计时器
此次引入了$_SERVER['REQUEST_TIME_FLOAT']数组变量,微秒级精度(百万分之一秒,float类型)。对于统计脚本运行时间会非常有用:
echo 'Executed in ', round(microtime(true) - $_SERVER['REQUEST_TIME_FLOAT'], 2)
16. 上传进度条Upload progress
文件上传进度反馈, 这个需求在当前是越来越普遍, 比如大附件邮件. 在PHP5.4以前, 我们可以通过APC提供的功能来实现. 或者使用PECL扩展uploadprogress来实现.
虽然说, 它们能很好的解决现在的问题, 但是也有很明显的不足:
1. 他们都需要额外安装(我们并没有打算把APC加入PHP5.4)
2. 它们都使用本地机制来存储这些信息, APC使用共享内存, 而uploadprogress使用文件系统(不考虑NFS), 这在多台前端机的时候会造成麻烦.
从PHP的角度来说, 最好的储存这些信息的地方应该是SESSION, 首先它是PHP原生支持的机制. 其次, 它可以被配置到存放到任何地方(支持多机共享).
正因为此, Arnaud Le Blanc提出了针对Session报告上传进度的RFC, 并且现在实现也已经包含在了PHP5.4的主干中。
通过$_SESSION["upload_progress_name"]就可以获得当前文件上传的进度信息,结合Ajax就能很容易实现上传进度条了。
17. Zend Signal in PHP 5.4
在PHP5.4中, 根据由Rasmus提交的RFC, 引入了一套新的信号处理机制, 目的是为了使得信号屏蔽机制可以应用到任何SAPI中, 并且提高在这个过程中的PHP性能.
新的机制, 叫做zend signal, 它的理念, 来自Yahoo的”延迟信号处理”(Yahoo signal deferring mechanism), 而后, facebook把这套理念加入了PHP中, 为了提升PHP+Apache 1.X下PHP调用ap_block/ap_unblock的性能.
18. PHP 5.4 由Arnaud 引入了一个对三元式的优化方案.
我们都知道PHP用写时复制来对变量复制做性能优化, 而在以前的三元式中, 却每次都会复制, 这在操作数是大数组的情况下, 会造成性能问题:
<?php $a = range(1, 1000); $i = 0; $start = microtime(true); while (++$i < 1000) { $b = isset($a)? $a : NULL; } var_dump(microtime(true) - $start);
二、删除的特性
1)最后,我们集中整理了几年来标记为已弃用的多个特性。这些特性包括 allow_call_time_pass_reference、define_syslog_variables、highlight.bg、register_globals、register_long_arrays、magic_quotes、safe_mode、zend.ze1_compatibility_mode、session.bug_compat42、session.bug_compat_warn 以及 y2k_compliance。
2) 备受指责的 Register Globals 已从 PHP 中完全删除。十年来,该特性一直以其频繁发生的安全漏洞而著称。2002年该特性被设置为默认关闭。2009年发布的 PHP5.3 将该特性标记为“弃用”,想必从那时起,大部分开发人员已经不再使用它。
3)除了这些特性之外,magic_quotes 可能是最大的危险。在早期版本中,未考虑因 magic_quotes 出错导致的后果,简单编写且未采取任何举措使自身免受 SQL 注入攻击的应用程序都通过 magic_quotes 来保护。如果在升级到 PHP 5.4 时未验证已采取正确的 SQLi 保护措施,则可能导致安全漏洞。
4)PHP 中的 break 和continue 语句之后可以跟上一个参数用来指明跳出的循环层数。如果不指定参数,它会像 VB、C#或 Java 一样跳出最内层的循环。在 PHP 5.4 之前,开发人员可以向 break 语句传递一个变量,而现在只能传递常量。
5)PHP 允许参数按引用传递。在早期版本中,你可以通过为调用点添加修饰来指明变量按引用传递。在 PHP 5.4 中,该选项已被移除。相反,现代 PHP 编程只需要在函数声明时指定按引用传递即可。与 C# 不同,你不需要同时在声明和调用点指定按引用传递。
三、其他改动和特性
有一种新的“可调用的”类型提示,用于某方法采用回调作为参数的情况。
htmlspecialchars() 和 htmlentities() 现在可更好地支持亚洲字符,如果未在 php.ini 文件中显式设置 PHP default_charset,这两个函数默认使用 UTF-8 而不是 ISO-8859-1。
=(精简回显语法)现在始终可用,无论 short_tags ini 设置的值为何。这应该使模板化系统创建者感到满意。
会话 ID 现在默认通过 /dev/urandom(或等效文件)中的熵生成,而不是与早期版本一样成为必须显式启用的一个选项。
mysqlnd 这一捆绑的 MySQL 原生驱动程序库现在默认用于与 MySQL 通信的各种扩展,除非在编译时通过 ./configure 被显式覆盖。
可能还有 100 个小的改动和特性。从 PHP 5.3 升级到 5.4 应该极为顺畅,但请阅读迁移指南加以确保。如果您从早期版本升级,执行的操作可能稍多一些。请查看以前的迁移指南再开始升级。
PHP 5.4版本将是最后一个支持Windows XP 和 Windows 2003的版本,今后将不再提供针对这些操作系统的二进制包。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









PHP 関数を通じて画像の遅延読み込み効果を最適化するにはどうすればよいですか?インターネットの発展に伴い、Web ページ内の画像の数が増加し、ページの読み込み速度に圧力がかかっています。ユーザーエクスペリエンスを向上させ、読み込み時間を短縮するために、画像の遅延読み込みテクノロジーを使用できます。画像の遅延読み込みにより、画像の読み込みが遅れる可能性があります。画像は、ユーザーが表示領域までスクロールしたときにのみ読み込まれるため、ページの読み込み時間が短縮され、ユーザー エクスペリエンスが向上します。 PHP Web ページを作成する場合、いくつかの関数を作成することで画像の遅延読み込み効果を最適化できます。詳細は以下

PHP 関数の紹介—curl_multi_getcontent(): cURL セッションのコンテンツを取得する PHP 開発では、ネットワークを介して他のサーバーにデータを要求することがよくあります。 cURL (ClientURL) は、PHP でのネットワーク通信に使用される強力な PHP 拡張ライブラリです。 cURL は一連の関数を提供します。そのうちの 1 つは、cURL セッションのコンテンツを取得するために使用されるcurl_multi_getcontent()です。

PHP 関数を使用してメモリ使用量を削減する方法 開発において、メモリ使用量は非常に重要な考慮事項です。プログラムで大量のメモリが使用されると、速度が低下したり、プログラムがクラッシュしたりする可能性があります。したがって、メモリ使用量を合理的に管理し削減することは、すべての PHP 開発者が注意を払うべき問題です。この記事では、PHP 関数を通じてメモリ使用量を削減するいくつかの方法を紹介し、読者の参考となる具体的なコード例を示します。 PHP で変数を解放するには、unset() 関数を使用します。変数が不要になった場合は、次を使用します。

PHPDeprecated: Functionereg_replace()isdeprecated-Solution PHP で開発する場合、一部の関数が非推奨と宣言されるという問題によく遭遇します。これは、最新の PHP バージョンでは、これらの関数が削除または置き換えられる可能性があることを意味します。一般的な例の 1 つは ereg_replace() 関数です。 ereg_replace

PHPの画像処理関数は、画像の加工・編集に特化した関数群であり、開発者に豊富な画像処理機能を提供します。これらの機能を通じて、開発者は画像のトリミング、拡大縮小、回転、透かしの追加などの操作を実装して、さまざまな画像処理のニーズを満たすことができます。まずはPHPの画像処理関数を使って画像の切り抜き機能を実現する方法を紹介します。 PHP には、画像のトリミングに使用できる imagecrop() 関数が用意されています。トリミング領域の座標とサイズを渡すことで、画像をトリミングできます

さまざまな PHP 関数のパフォーマンスは、アプリケーションの効率にとって非常に重要です。パフォーマンスの良い関数には echo や print などがありますが、str_replace、array_merge、file_get_contents などの関数のパフォーマンスは低くなります。たとえば、str_replace 関数は文字列の置換に使用され、中程度のパフォーマンスを発揮しますが、sprintf 関数は文字列の書式設定に使用されます。パフォーマンス分析によると、1 つの例の実行にかかる時間はわずか 0.05 ミリ秒であり、関数が適切に実行されることが証明されています。したがって、関数を賢く使用すると、アプリケーションをより高速かつ効率的に実行できます。

PHP 関数には他の言語の関数との類似点がありますが、いくつかの独自の機能もあります。構文的には、PHP 関数は function で宣言され、JavaScript は function で宣言され、Python は def で宣言されます。パラメータと戻り値の点では、PHP 関数はパラメータを受け入れて値を返します。JavaScript と Python にも同様の関数がありますが、構文が異なります。スコープに関しては、PHP、JavaScript、Python の関数はすべてグローバル スコープまたはローカル スコープを持ち、グローバル関数にはどこからでもアクセスできますが、ローカル関数には宣言スコープ内でのみアクセスできます。

PHP 関数と Flutter 関数の主な違いは、宣言、構文、戻り値の型です。 PHP 関数は暗黙的な戻り値の型変換を使用しますが、Flutter 関数は ? を通じてオプションのパラメータを指定できますが、Flutter 関数は必須パラメータと [] を使用して名前付けパラメータを渡します。 Flutter 関数は、{} を使用して名前付きパラメータを指定します。
