ホームページ  >  記事  >  バックエンド開発  >  PHP の実行効率を高めるための 50 のヒントを分析する

PHP の実行効率を高めるための 50 のヒントを分析する

WBOY
WBOYオリジナル
2016-06-13 12:28:07817ブラウズ

PHP の実行効率を向上させる 50 のヒントの分析

1. 文字列を含めるには二重引用符の代わりに一重引用符を使用すると高速になります。 PHP は二重引用符で囲まれた文字列内の変数を検索しますが、一重引用符は検索しません。 注: これを実行できるのは echo だけです。これは複数の文字列をパラメータとして受け取ることができる「関数」です (注釈: PHP マニュアル echo は実際の関数ではなく言語構造であるため、関数は二重引用符で囲まれています)。

2. クラスメソッドを静的に定義できる場合は、それを静的に定義してみると、速度が 4 倍近く向上します。

3. $row[‘id’] は $row[id] より 7 倍高速です。

4. Echo は print より高速で、echo $str1、$str2 などの文字列連結の代わりに echo の複数のパラメーター (注釈: ピリオドの代わりにカンマを使用することを指します) を使用します。

5. for ループを実行する前に最大ループ数を決定します。ループごとに最大値を計算するのではなく、代わりに foreach を使用することをお勧めします。

6. 未使用の変数、特に大きな配列の登録を解除して、メモリを解放します。

7. __​​get、__set、__autoload の使用は避けてください。

8. require_once() は高価です。

9. ファイルをインクルードする場合は、絶対パスを使用するようにしてください。これにより、include_path 内のファイルを検索する PHP の速度が低下し、オペレーティング システムのパスの解析に必要な時間が短縮されます。

10. スクリプトの実行開始時刻 (注釈: サーバーがクライアント要求を受信する) を知りたい場合は、time( よりも

$_SERVER['REQUEST_TIME'] を使用する方が良いです) )

11. 関数は正規表現を置き換えて同じ関数を完成させます。

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

13. 文字列置換関数がパラメータとして配列または文字を受け入れ、パラメータの長さが長すぎない場合は、単に記述するのではなく、渡される各パラメータが 1 文字になるように追加の置換コードを記述することを検討できます。配列をクエリおよび置換のパラメータとして受け入れるための 1 行のコード。

14. 複数の if、else if ステートメントを使用するよりも、選択的分岐ステートメント (翻訳アノテーション: switch case) を使用する方が適切です。

[email protected]、非常に非効率です。

16. Apache の mod_deflate モジュールを開くと、Web ページの閲覧速度が向上します。

17. データベース接続は使用が終了したら閉じる必要があり、長時間の接続は使用しないでください。

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

19. メソッド内でローカル変数を増やすのが最も早いです。関数内でローカル変数を呼び出すのとほぼ同じ速度です。

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

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

22. 未定義のローカル変数のインクリメントは、事前定義されたローカル変数のインクリメントより 9 ~ 10 倍遅くなります。

23. 関数内で呼び出さずにローカル変数を定義するだけでも、(ローカル変数をインクリメントするのと同じ程度に) 速度が低下します。 PHP はおそらく、グローバル変数が存在するかどうかを確認します。

24. 10 個のメソッド (テスト メソッドの前後の両方) を追加しましたが、パフォーマンスに変化はなかったので、メソッド呼び出しはクラスで定義されたメソッドの数とは無関係であるように見えます。

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

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

27. Apache が PHP スクリプトを解析するのにかかる時間は、静的な HTML ページを解析する場合よりも 2 ~ 10 倍遅くなります。使用する静的な HTML ページを増やし、スクリプトを減らすようにしてください。

28. スクリプトをキャッシュできない場合、呼び出されるたびに再コンパイルされます。 PHP キャッシュ メカニズムを導入すると、通常、コンパイルのオーバーヘッドが排除され、パフォーマンスが 25% ~ 100% 向上します。

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

30. 文字列を操作し、その長さが特定の要件を満たしているかどうかを確認する必要がある場合は、当然 strlen() 関数を使用します。この関数は計算を行わず、zval 構造体 (PHP 変数の格納に使用される C の組み込みデータ構造体) に格納されている既知の文字列長を返すだけなので、非常に高速に実行されます。ただし、strlen() は関数であるため、関数呼び出しは小文字などの多くの手順を経るため、多少遅くなります (注釈: 小文字の関数名を指します。PHP は関数名の大文字と小文字を区別しません)。 )、ハッシュ検索、呼び出された関数と一緒に実行されます。場合によっては、 isset() トリックを使用してコードの実行を高速化できます。

(下記例)

if (strlen($foo) < 5) { echo “Foo is too short”$$ }

(以下の手法で行うCompare)

if (!isset($foo{5})) { echo “Foo は短すぎます”$$ }

isset() の呼び出しは、strlen() よりも高速であるため、 with 後者との違いは、 isset() が言語構造として、その実行に関数検索と小文字が必要ないことを意味します。つまり、実際には、最上位コードで文字列の長さをチェックするオーバーヘッドはそれほどかかりません。

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

32. オブジェクト指向 (OOP) である必要はありません。オブジェクト指向は多くの場合非常に高価であり、各メソッドとオブジェクトの呼び出しは大量のメモリを消費します。

33. すべてのデータ構造を実装するためにクラスを使用する必要はありません。

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

35. 必要に応じて、コードをメソッドに分割できます。

36. 多数の PHP 組み込み関数を使用してみます。

37. コード内に時間のかかる関数が多数ある場合は、C 拡張機能を使用して実装することを検討できます。

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

39. mod_zip を Apache モジュールとして使用すると、データを瞬時に圧縮し、データ転送量を 80% 削減できます。

40. file、fopen、feof、fgets などの一連のメソッドの代わりに file_get_contents を使用できる場合は、より効率的であるため、file_get_contents を使用するようにしてください。ただし、ファイルを開くときは、file_get_contents の使用に注意してください。 URL ファイル。

41. PHP のファイル操作は非効率ではありませんが、実行するファイル操作は最小限に抑えます。可能です。挿入と更新の操作を実行します (更新ページで批判されました)。

43. 可能な限り PHP の内部関数を使用します (ただし、PHP に存在しない関数を見つけるために時間を無駄にしました)。 . カスタム関数を書くのにどれくらい時間がかかりますか? それは経験の問題です!);

44. ループ内で変数、特に大きな変数を宣言しないでください (これは単なる問題ではないようです) PHP ではそうですよね?) ;

45. 多次元配列でネストされた割り当てをしないようにしてください。PHP の内部文字列操作関数を使用できる場合は、正規表現を使用しないでください。

47. while ループと for ループの代わりに foreach を使用するようにしてください。

49 . "i を i =1 =i 1 に置き換えます。c/c の習慣に従って、効率は依然として高いです。"

50. グローバル変数は使用後に unset() する必要があります。

51. checkdnsrr() を使用して、ドメイン名の存在を通じて一部の電子メール アドレスの有効性を確認します。

52 を使用している場合。 php5 および mysql4.1 の場合、mysql_

;

53 の改良された関数 mysqli_

を使用することを検討してください。highlight_file() を使用して、適切にフォーマットされたページ ソース コードのコピーを自動的に印刷します。

54. error_reporting (0) 関数を使用して、機密情報がユーザーに表示されないようにします。理想的には、php.ini ファイルでエラー報告を完全に無効にする必要があります。ただし、共有仮想ホストを使用していて php.ini を変更できない場合は、error_reporting(0) 関数を追加して各スクリプト ファイルの最初の行に配置する (または require_once() でロードする) ことをお勧めします。これにより、エラー発生時に機密 SQL クエリとパスが表示されないように効果的に保護できます。
55. error_reporting(0) 関数を使用して、潜在的に機密情報がユーザーに表示されないようにします。理想的には、php.ini ファイルでエラー報告を完全に無効にする必要があります。ただし、共有仮想ホストを使用していて php.ini を変更できない場合は、error_reporting(0) 関数を追加して各スクリプト ファイルの最初の行に配置する (または require_once() でロードする) ことをお勧めします。これにより、エラー発生時に機密 SQL クエリとパスが表示されないように効果的に保護できます。
56. パラメーター変数のアドレスを参照することで、関数に複数の戻り値を持たせます。値ではなくアドレスで渡すことを示すために変数の前に「&」を追加できます。 57. すべてのエスケープされたデータをデータベースに挿入する必要はありません。 PHP に入力されるデータはエスケープされるため、プログラムの実行効率に一定の影響を与えます。実行時にエスケープ関数 (addslashes() など) を呼び出す方が効率的です
58. ip2long() 関数と long2ip() 関数を使用して IP アドレスを整数型に変換し、データベースに格納します文字タイプの代わりに。これにより、保管スペースが約 1/4 に削減されます。同時に、アドレスを簡単にソートし、迅速に検索できます。

59、
データベースを保存 (取得) するときに、大容量の文字列を圧縮 (解凍) するには gzcompress() と gzuncompress() を使用します。この組み込み関数は、gzip アルゴリズムを使用して最大 90% 圧縮できます。

60. ドメイン名の存在を通じて一部の電子メール アドレスの有効性を確認するには、checkdnsrr() を使用します。この組み込み関数により、各ドメイン名が IP アドレスに対応することが保証されます。

61、一部の場所では strlen の代わりに isset が使用されます

文字列を操作し、その長さが特定の要件を満たしているかどうかを確認する必要がある場合は、当然 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() とは異なるため、たまたま strlen() よりも高速です。さらに、言語構造としての isset() は、その実行に関数の検索や小文字が必要ないことを意味します。つまり、実際には、最上位コードで文字列の長さをチェックするオーバーヘッドはそれほどかかりません。

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