ホームページ >バックエンド開発 >PHPチュートリアル >PHP コードの最適化の概要
[はじめに] 1- モジュール化されたコードを作成します。 優れた PHP コードはモジュール化されたコードである必要があります。 PHP のオブジェクト指向プログラミング機能は、アプリケーションを関数またはメソッドに分割するための特に強力なツールです。フロントエンドの HTML CSS JavaS をアプリケーションのサーバー側からできるだけ分離する必要があります
優れた PHP コードはモジュラー コードである必要があります。 PHP のオブジェクト指向プログラミング機能は、アプリケーションを関数またはメソッドに分割するための特に強力なツールです。フロントエンドの HTML/CSS/JavaScript コードをアプリケーションのサーバー側からできるだけ分離する必要があります。任意の PHP フレームワークで MVC (モデル-ビュー-コントローラー) パターンに従うこともできます。
優れた PHP コードには、コーディング標準の完全なセットが必要です。変数と関数の名前付け、データベースへのアクセスとエラー処理の統一された方法、および同じコードのインデント方法を通じてプログラミング標準を達成すると、コードが読みやすくなります。
優れた PHP コードは移植可能である必要があります。マジック クオートや短いタグなどの PHP の既存の機能を使用できます。ニーズを理解してから、PHP の機能を適応させて自己完結型で移植可能なコードを作成してください。
優れた PHP コードは安全である必要があります。 PHP5 は優れたパフォーマンスと柔軟性を提供します。しかし、セキュリティの問題は完全に開発者にあります。プロの PHP 開発者にとって、クロスサイト スクリプティング (XSS)、クロスサイト リクエスト フォージェリ (CSRF)、コード インジェクションの脆弱性、文字エンコードの脆弱性などの主要なセキュリティの脆弱性を深く理解することが重要です。 mysql_real_escape_string などの PHP の特別な機能と関数を使用すると、安全なコードを作成できます。
コード コメントはコードの重要な部分です。コードのコメントを通じて、変数や関数が何をするのかを知ることができ、将来のコードのメンテナンスに非常に役立ちます。
すべての短いタグを完全な PHP タグに置き換えます。
文字列内の変数の PHP 検索によるパフォーマンスの低下を避けるために、文字列では二重引用符の代わりに常に一重引用符を使用します。 文字列を二重引用符で囲むよりも一重引用符で囲んだほうが高速です。 PHP は二重引用符で囲まれた文字列内の変数を検索するため、一重引用符は検索しません
一重引用符 (') も確実に検索されるように、htmlspecialchars 関数に渡すパラメーターとして ENT_QUOTES を使用します。 HTML エンティティに変換することをお勧めします。
echo ステートメントを通じてカンマ (,) で区切られた文字列を出力すると、文字列連結演算子 (.) を使用するよりもパフォーマンスが向上します。
出力する前に渡された値$_GET['query']を確認してください。 isset 関数または empty 関数を使用すると、変数が null かどうかを確認できます。
クラスメソッドをstaticとして定義できるのであれば、それをstaticとして定義してみると、速度が4倍近く向上します。
$row['id'] は $row[id] より 7 倍高速です。
echo は print より高速で、echo $str1,$str2 などの文字列連結の代わりに echo の複数のパラメーター (注釈: ピリオドの代わりにカンマを参照) を使用します。
for ループを実行する前にループの最大数を決定します。ループごとに最大値を計算するのではなく、代わりに foreach を使用することをお勧めします。
未使用の変数、特に大きな配列の登録を解除して、メモリを解放します。
__get、__set、__autoload の使用は避けてください。
require_once() は高価です。
ファイルをインクルードするときは、絶対パスを使用するようにしてください。これにより、include_path 内のファイルを検索する PHP の速度が低下し、オペレーティング システムのパスの解析にかかる時間が短縮されるからです。
スクリプトの実行開始時刻 (注釈: サーバーがクライアント要求を受信する時刻) を知りたい場合は、time() よりも $_SERVER['REQUEST_TIME'] を使用する方が適しています。
関数は正規表現を置き換えて同じ関数を完成させます。
str_replace 関数は preg_replace 関数より高速ですが、strtr 関数は str_replace 関数より 4 倍効率的です。
文字列置換関数が配列または文字をパラメーターとして受け入れ、パラメーターの長さが長すぎない場合は、渡される各パラメーターが 1 文字になるように、1 文字だけを記述するのではなく、追加の置換コードを記述することを検討できます。コード行 クエリおよび置換のパラメータとして配列を受け入れます。
複数の if、else if ステートメントを使用するよりも、選択的分岐ステートメント (翻訳: switch case) を使用する方が良いです。
@ を使用してエラー メッセージをブロックする方法は、非常に非効率的です。
Apache の mod_deflate モジュールを開いて、Web ブラウジング速度を向上させます。
データベース接続は、使用が終了したら閉じる必要があります。長い接続は使用しないでください。
エラーメッセージは高価です。
メソッド内でローカル変数をインクリメントするのが最も速いです。関数内でローカル変数を呼び出すのとほぼ同じ速度です。
グローバル変数のインクリメントは、ローカル変数のインクリメントより 2 倍遅くなります。
オブジェクト プロパティ (例: $this->prop++) のインクリメントは、ローカル変数のインクリメントより 3 倍遅くなります。
未定義のローカル変数をインクリメントするのは、事前定義されたローカル変数をインクリメントするよりも 9 ~ 10 倍遅くなります。
関数内で呼び出さずにローカル変数を定義するだけでも、(ローカル変数をインクリメントするのと同じ程度に)速度が低下します。 PHP はおそらく、グローバル変数が存在するかどうかを確認します。
10 個のメソッドを (メソッドのテスト前とテスト後の両方で) 追加したため、メソッド呼び出しはクラスで定義されたメソッドの数とは無関係であるように見えますが、パフォーマンスには変化がありませんでした。
派生クラスのメソッドは、基本クラスで定義された同じメソッドよりも高速に実行されます。
1 つのパラメーターを指定して空の関数を呼び出すには、7 ~ 8 回のローカル変数のインクリメント操作を実行するのと同じ時間がかかります。同様のメソッド呼び出しには、15 近くのローカル変数の増分が必要です。
Apache が PHP スクリプトを解析するのにかかる時間は、静的な HTML ページを解析するよりも 2 ~ 10 倍遅くなります。使用する静的な HTML ページを増やし、スクリプトを減らすようにしてください。
スクリプトをキャッシュできない限り、呼び出されるたびに再コンパイルされます。 PHP キャッシュ メカニズムを導入すると、通常、コンパイルのオーバーヘッドが排除され、パフォーマンスが 25% ~ 100% 向上します。
できるだけキャッシュするようにしてください。memcached を使用できます。 Memcached は、動的 Web アプリケーションを高速化し、データベースの負荷を軽減するために使用できる高性能メモリ オブジェクト キャッシュ システムです。 OP コードのキャッシュは、リクエストごとにスクリプトを再コンパイルする必要がないように便利です。
文字列を操作し、その長さが特定の要件を満たしているかどうかを確認する必要がある場合は、当然 strlen() 関数を使用します。この関数は計算を行わず、zval 構造体 (PHP 変数の格納に使用される C の組み込みデータ構造体) に格納されている既知の文字列長を返すだけなので、かなり高速に実行されます。ただし、strlen() は関数であるため、関数呼び出しは小文字などの多くの手順を経るため、多少遅くなります (注釈: 小文字の関数名を指します。PHP は関数名の大文字と小文字を区別しません)。 )、ハッシュ検索、呼び出された関数と一緒に実行されます。場合によっては、 isset() トリックを使用してコードの実行を高速化できます。
(举例如下) if (strlen($foo) < 5) { echo 'Foo is too short'; }
(与下面的技巧做比较) if (!isset($foo[5])) { echo 'Foo is too short'; }
isset() の呼び出しは、strlen() よりも高速です。これは、後者とは異なり、言語構造としての isset() は、その実行に関数の検索と小文字が必要ないことを意味するためです。つまり、文字列の長さをチェックするトップレベルのコードでは、実際には多くのオーバーヘッドが費やされません。
変数 $i のインクリメントまたはデクリメントを実行する場合、$i++ は ++$i よりも遅くなります。この違いは PHP に固有のものであり、他の言語には当てはまりません。そのため、C または Java コードを変更して、すぐに高速になることを期待しないでください。実際には機能しません。 ++$i は 3 つの命令 (オペコード) しか必要としないため高速ですが、$i++ は 4 つの命令を必要とします。ポストインクリメントは実際には、後でインクリメントされる一時変数を作成します。プレフィックスの増分は、元の値に直接増加します。これは、Zend の PHP オプティマイザーによって行われるような、最適化の一種です。すべてのコマンド オプティマイザーが同じ最適化を実行するわけではなく、コマンド オプティマイザーがインストールされていないインターネット サービス プロバイダー (ISP) やサーバーが多数存在するため、この最適化を念頭に置くことをお勧めします。
必ずしもオブジェクト指向 (OOP) である必要はありません。オブジェクト指向は多くの場合非常に高価であり、各メソッドとオブジェクトの呼び出しは大量のメモリを消費します。
すべてのデータ構造を実装するためにクラスを使用する必要はありません。配列も非常に便利です。
メソッドを細分化しすぎず、実際にどのコードを再利用するのかを慎重に考えてください。
必要に応じていつでもコードをメソッドに分割できます。
多数の PHP 組み込み関数を使用してみてください。
コード内に時間のかかる関数が多数ある場合は、それらを C 拡張機能として実装することを検討できます。
コードをプロファイリングします。チェッカーは、コードのどの部分にどれくらいの時間がかかっているかを示します。 Xdebug デバッガーには、コードの全体的な整合性を評価し、コード内のボトルネックを明らかにする検査ルーチンが含まれています。
mod_zip を Apache モジュールとして使用すると、データを即座に圧縮し、データ転送量を 80% 削減できます。
file、fopen、feof、fgets およびその他の一連のメソッドの代わりに file_get_contents を使用できる場合は、より効率的である file_get_contents を使用するようにしてください。ただし、URL ファイルを開くときは file_get_contents の PHP バージョンの問題に注意してください
PHP のファイル操作効率は低くありませんが、Select SQL ステートメントを最適化してください。可能な場合は、挿入操作と更新操作をできるだけ少なくします (更新ページで批判されました)
可能な限り PHP 内部関数を使用します (ただし、PHP に存在しない関数を見つけるのに時間を無駄にしました)。カスタム関数の作成にかかる時間は経験の問題です);
ループ内で変数、特に大きな変数を宣言しないでください: オブジェクト (これは PHP だけの問題ではないようですよね?)
多次元配列のループ内で代入をネストしないようにしてください。
以上がPHP コードの最適化の概要の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。