ホームページ  >  記事  >  バックエンド開発  >  PHP コードを最適化するための 40 のヒント

PHP コードを最適化するための 40 のヒント

WBOY
WBOYオリジナル
2016-06-13 13:04:09782ブラウズ

PHP コードを最適化するための 40 のヒント
英語の著作権は Reinhold Weber に属し、中国語の翻訳は yangyang (別名 davidkoree) が執筆しています。バイリンガル版は非営利目的の配布に使用できますが、英語版の作成者、著作権情報、および中国語訳の作成者に注意する必要があります。


1. メソッドが静的である可能性がある場合は、静的であると宣言します。メソッドが静的である可能性がある場合は、静的であると宣言します。速度は4倍まで上げることができます。

2. echo は print よりも高速です。

3. 文字列連結の代わりに echo の複数のパラメータを使用します。 文字列の連結の代わりに echo の複数のパラメータを使用します。

4. for ループの最大値をループ内ではなく前に設定し、ループするたびに最大値を計算しないでください。

5. 変数の設定を解除してメモリ (特に大きな配列) を解放します。

6. __get、__set、__autoload のような魔法を避ける __get、__set、__autoload の使用は避けてください。

7. require_once() は高価です require_once() は高価です。

8. include と require で完全なパスを使用すると、OS パスの解決に費やす時間が短縮されます。

9. スクリプトの実行開始時刻を確認する必要がある場合は、time() クライアント要求よりも $_SERVER['REQUEST_TIME'] を使用することをお勧めします。 ]時間()より。

10. 正規表現の代わりに strncasecmp、strpbrk、stripos 関数を使用できるかどうかを確認して、同じ関数を完成させることができるかどうかを確認します。

11. str_replace は preg_replace よりも高速ですが、strtr は str_replace よりも 4 倍高速です。str_replace 関数は preg_replace 関数よりも高速ですが、strtr 関数は str_replace 関数よりも 4 倍効率的です。

12. 文字列置換関数などの関数が引数として配列と単一文字の両方を受け入れ、引数リストが長すぎない場合は、一度に 1 文字を渡す冗長な置換ステートメントをいくつか作成することを検討してください。文字列置換関数が配列または文字をパラメータとして受け入れ、パラメータの長さが長すぎない場合は、それぞれのパラメータが長すぎないように、追加の置換コードを記述することを検討できます。パラメータを文字として渡すコードを 1 行記述するだけではなく、配列をクエリとして受け入れ、パラメータを置き換えます。

13. 複数の if、else if ステートメントよりも select ステートメントを使用する方が適切です。

14. @ を使用したエラー抑制は非常に遅くなります。

15. Apache の mod_deflate をオンにする Apache の mod_deflate モジュールをオンにします。

16. 作業が完了したら、データベース接続を閉じます。

17. $row['id'] は $row[id] より 7 倍高速です。

18. エラー メッセージは高価です。

19. for ($x=0; $x < count($array); $x) などの関数を for ループ内で使用しないでください。 count() 関数は毎回呼び出されます。 for ループでは関数を使用しないでください。たとえば、for ($x=0; $x < count($array); $x) はループするたびに count() 関数を呼び出します。

20. メソッド内でローカル変数をインクリメントするのは、関数内でローカル変数をインクリメントするのとほぼ同じです。関数内でローカル変数を呼び出すのとほぼ同じ速度です。

21. グローバル変数のインクリメントはローカル変数の 2 倍遅くなります。

22. オブジェクト プロパティ (例: $this->prop++) のインクリメントは、ローカル変数のインクリメントよりも 3 倍遅くなります。ローカル変数は 3 倍遅くなります。

23. 未定義のローカル変数のインクリメントは、初期化済みのローカル変数のインクリメントよりも 9 ~ 10 倍遅くなります。

24. 関数内で使用せずにグローバル変数を宣言するだけでも、処理が遅くなります (ローカル変数をインクリメントするのとほぼ同じ量)。おそらく、PHP はローカル変数が存在するかどうかを確認します。関数内で変数を呼び出さない場合も、(ローカル変数をインクリメントするのと同じ程度に) 速度が低下します。 PHP はおそらく、グローバル変数が存在するかどうかを確認します。

25. テスト クラスに 10 個のメソッドを (テスト メソッドの前後に) 追加しましたが、パフォーマンスに変化はありませんでした。追加したため、メソッドの数は関係ありません。 10 の方法 (テスト方法の前後両方) を実行しましたが、パフォーマンスに変化はありませんでした。

26. 派生クラスのメソッドは、基本クラスで定義されたメソッドよりも高速に実行されます。

27. 1 つのパラメーターと空の関数本体を持つ関数呼び出しには、7 ~ 8 回の $localvar++ 操作を実行するのとほぼ同じ時間がかかります。パラメータには 7 ~ 8 個のローカル変数の増分時間がかかります。同様のメソッド呼び出しには、15 近くのローカル変数のインクリメント操作が必要です。

28. 文字列を " の代わりに ' で囲むと、php は変数を "…" 内ではなく "…" 内で検索するため、解釈が少し速くなります。 もちろん、これを実行できるのは、'文字列内に変数を含める必要はありません。文字列を二重引用符で囲むよりも一重引用符で囲んだほうが高速です。PHP は二重引用符で囲まれた文字列内で変数を検索しますが、一重引用符で囲まれていない場合にのみ機能します。

29. 文字列をエコーする場合は、ドットではなくカンマで区切った方が高速です。これは、複数の文字列を受け取ることができる関数であるため、のみ機能します。複数の文字列を出力する場合は、文字列を区切るためにピリオドの代わりにカンマを使用すると高速です。 注: これは、複数の文字列をパラメータとして受け取ることができるメソッドです (注釈: PHP マニュアル)。 echo は言語構造であり、実際の関数ではないため、関数は二重引用符で囲まれています)

30. PHP スクリプトは、静的 HTML ページよりも少なくとも 2 ~ 10 倍遅く処理されます。 Apache: より多くの静的 HTML ページとより少ないスクリプトを使用するようにしてください。Apache は、静的 HTML ページをより多く使用し、より少ないスクリプトを使用するようにしてください。 PHP スクリプトは、スクリプトがキャッシュされていない限り、毎回再コンパイルされます。PHP キャッシュ製品をインストールすると、コンパイル時間が短縮され、通常はすべてが再コンパイルされます。 PHP キャッシュ メカニズムを導入すると、通常、コンパイルのオーバーヘッドが排除され、パフォーマンスが 25% ~ 100% 向上します。

32. 可能な限りキャッシュを使用します。memcached は、データベースの負荷を軽減することで動的 Web アプリケーションを高速化することを目的とした高性能メモリ オブジェクト キャッシュ システムです。リクエストごとにコンパイルする必要があるため、できる限りキャッシュするようにしてください。memcached を使用できます。 Memcached は、動的 Web アプリケーションを高速化し、データベースの負荷を軽減するために使用できる高性能メモリ オブジェクト キャッシュ システムです。 OP コードのキャッシュは、リクエストごとにスクリプトを再コンパイルする必要がないように便利です。

33. 文字列を操作する場合、文字列が特定の長さであることを確認する必要がある場合は、当然のことながら strlen() 関数を使用する必要があります。任意の計算を実行しますが、zval 構造体 (PHP で変数を格納するために使用される内部 C 構造体) で使用できる既知の文字列の長さを返すだけです。ただし、 strlen() は関数であるため、関数呼び出しにはいくつかの操作が必要であり、それでも多少遅いです。たとえば、小文字とハッシュテーブルの検索とその後の関数の実行など、 isset() トリックを使用してコードの速度を向上させることができます。 もちろん、strlen() 関数を使用します。この関数は計算を行わず、zval 構造体 (PHP 変数の格納に使用される C の組み込みデータ構造体) に格納されている既知の文字列長を返すだけなので、非常に高速に実行されます。ただし、strlen() は関数であるため、関数呼び出しは小文字などの多くの手順を経るため、多少遅くなります (注釈: 小文字の関数名を指します。PHP は関数名の大文字と小文字を区別しません)。 )、ハッシュ検索、呼び出された関数と一緒に実行されます。場合によっては、 isset() トリックを使用してコードの実行を高速化できます。
例 (以下の例)
if (strlen($foo) < 5) { echo "Foo is too short" }
vs. (以下の手法と比較してください) !isset($foo{5})) { echo "Foo が短すぎます" }
;isset() の呼び出しは、 strlen() よりも高速です。これは、 strlen() とは異なり、 isset() は言語構造体であり、関数の実行に関数の検索や小文字を必要としないためです。 これは、実質的にオーバーヘッドがないことを意味します。文字列の長さを決定する実際のコードでは、isset() の呼び出しは strlen() よりも高速です。これは、後者とは異なり、isset() は言語構造として、その実行に関数の検索や小文字が必要ないためです。変化。つまり、文字列の長さをチェックするトップレベルのコードでは、実際にはそれほどオーバーヘッドがかかりません。

34. 変数 $i++ の値をインクリメントまたはデクリメントする場合、++$i よりも少し遅くなります。これは PHP 固有のものであり、他の言語には当てはまらないため、変更しないでください。 C または Java コードが突然高速になると考えていると、$i++ に使用される 4 つのオペコードの代わりに 3 つしか必要ないため、++$i が PHP で高速になることはありません。実際には、ポスト インクリメントによって、これは、Zend の PHP オプティマイザーと同様に、オペコードが最適化する最適化の 1 つですが、すべてのオペコード オプティマイザーがこの最適化を実行するわけではないため、注意が必要です。また、オペコード オプティマイザーを使用せずに実行されている ISP やサーバーも数多くあります。変数 $i のインクリメントまたはデクリメントを実行すると、$i++ は ++$i よりも遅くなります。この違いは PHP に固有のものであり、他の言語には当てはまりません。そのため、C または Java コードを変更して、すぐに高速になることを期待しないでください。実際には機能しません。 ++$i は 3 つの命令 (オペコード) しか必要としないため高速ですが、$i++ は 4 つの命令を必要とします。ポストインクリメントでは、実際には、後でインクリメントされる一時変数が作成されます。プレフィックスの増分は、元の値に直接増加します。これは、Zend の PHP オプティマイザーによって行われるような、最適化の一種です。すべてのコマンド オプティマイザーが同じ最適化を実行するわけではなく、コマンド オプティマイザーがインストールされていないインターネット サービス プロバイダー (ISP) やサーバーが多数存在するため、この最適化を念頭に置くことをお勧めします。

35. すべてを OOP にする必要はありません。多くの場合、オーバーヘッドが大きくなり、各メソッドとオブジェクトの呼び出しが大量のメモリを消費します。

36. すべてのデータ構造をクラスとして実装しないでください。配列も便利です。すべてのデータ構造をクラスとして実装しないでください。配列も便利です。

37. メソッドを分割しすぎないで、実際にどのコードを再利用するかを考えてください。メソッドを分割しすぎないで、実際にどのコードを再利用するかを考えてください。

38. 必要に応じていつでもメソッドのコードを分割できます。

39. 多数の PHP 組み込み関数を活用してみましょう。

40. コード内に非常に時間のかかる関数がある場合は、C 拡張機能として記述することを検討してください。

41. プロファイラーは、コードのどの部分がどのくらいの時間を費やしているかを示します。プロファイリングには、コードのボトルネックがすでに含まれています。チェッカーは、コードのどの部分にどれくらいの時間がかかっているかを示します。 Xdebug デバッガーには、コードの全体的な整合性を評価し、コード内のボトルネックを明らかにする検査ルーチンが含まれています。

42. Apache モジュールとして使用できる mod_gzip は、オンザフライでデータを圧縮し、転送するデータを最大 80% 削減できます。mod_gzip は、オンザフライでデータを圧縮する Apache モジュールとして使用できます。データ通信量を80%削減できます。

43. php の最適化に関する優れた記事 (http://phplens.com/lens/php-book/optimizing-debugging-php.php) by John Lim PHP の最適化に関する別の優れた記事 (John Lim 著)リム。



声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。