この記事では、PHP における最適化の提案とコードの最適化についてまとめており、PHP プログラマーに良い提案をしています
1. クラス メソッドを静的として定義できる場合は、それを静的に定義してみると、速度が 4 倍近く向上します。
2. $row[’id’] の速度は $row[id] の 7 倍です。
3. Echo は print より高速で、echo $str1、$str2 などの文字列連結の代わりに echo の複数のパラメーター (注釈: ピリオドの代わりにカンマを使用することを指します) を使用します。
4. for ループを実行する前に最大ループ数を決定します。ループごとに最大値を計算するのではなく、代わりに foreach を使用することをお勧めします。
5. 未使用の変数、特に大きな配列の登録を解除して、メモリを解放します。
6. __get、__set、__autoload の使用は避けてください。
7. require_once() は高価です。
8. ファイルをインクルードする場合は、絶対パスを使用するようにしてください。これにより、include_path 内のファイルを検索する PHP の速度が低下し、オペレーティング システムのパスの解析に必要な時間が短縮されます。
9. スクリプトの実行開始時刻 (注釈: サーバーがクライアント要求を受信する) を知りたい場合は、time() よりも $_SERVER[‘REQUEST_TIME’] を使用する方が良いでしょう。
10. 関数は正規表現を置き換えて同じ関数を完成させます。
11. str_replace 関数は preg_replace 関数よりも高速ですが、strtr 関数は str_replace 関数よりも 4 倍効率的です。
12. 文字列置換関数がパラメーターとして配列または文字を受け入れ、パラメーターの長さが長すぎない場合は、単に 1 行のコードを記述するのではなく、渡される各パラメーターが文字になるように追加の置換コードを記述することを検討できます。配列をクエリおよび置換のパラメータとして受け入れます。
13. 複数の if、else if ステートメントを使用するよりも、選択的分岐ステートメント (翻訳アノテーション: switch case) を使用する方が適切です。
14. @ を使用してエラー メッセージをブロックするのは非常に非効率的です。
15. Apache の mod_deflate モジュールをオンにして、Web ページの閲覧速度を向上させます。
16. データベース接続は、使用が終了したら閉じる必要があります。長い接続は使用しないでください。
17. エラーメッセージは高価です。
18. メソッド内でローカル変数をインクリメントするのが最も高速です。関数内でローカル変数を呼び出すのとほぼ同じ速度です。
19. グローバル変数のインクリメントは、ローカル変数のインクリメントより 2 倍遅くなります。
20. オブジェクト プロパティ ($this->prop++ など) のインクリメントは、ローカル変数のインクリメントより 3 倍遅くなります。
21. 未定義のローカル変数をインクリメントするのは、事前定義されたローカル変数をインクリメントするよりも 9 ~ 10 倍遅くなります。
22. 関数内で呼び出さずにローカル変数を定義するだけでも、(ローカル変数をインクリメントするのと同じ程度に) 速度が低下します。 PHP はおそらく、グローバル変数が存在するかどうかを確認します。
23. 10 個のメソッドを追加したため (メソッドのテスト前とテスト後の両方)、メソッド呼び出しはクラスで定義されているメソッドの数に依存していないように見えますが、パフォーマンスに変化はありませんでした。
24. 派生クラスのメソッドは、基本クラスで定義された同じメソッドよりも高速に実行されます。
25. 1 つのパラメーターを指定して空の関数を呼び出すには、7 ~ 8 回のローカル変数のインクリメント操作を実行するのと同じ時間がかかります。同様のメソッド呼び出しには、15 近くのローカル変数の増分が必要です。
26. Apache が PHP スクリプトを解析するのにかかる時間は、静的な HTML ページを解析するよりも 2 ~ 10 倍遅くなります。使用する静的な HTML ページを増やし、スクリプトを減らすようにしてください。
27. スクリプトをキャッシュできない限り、呼び出されるたびに再コンパイルされます。 PHP キャッシュ メカニズムを導入すると、通常、コンパイルのオーバーヘッドが排除され、パフォーマンスが 25% ~ 100% 向上します。
28. できるだけキャッシュするようにしてください。memcached を使用できます。 Memcached は、動的 Web アプリケーションを高速化し、データベースの負荷を軽減するために使用できる高性能メモリ オブジェクト キャッシュ システムです。 OP コードのキャッシュは、リクエストごとにスクリプトを再コンパイルする必要がないように便利です。
29. 文字列を操作し、その長さが特定の要件を満たしているかどうかを確認する必要がある場合は、当然 strlen() 関数を使用します。この関数は計算を行わず、zval 構造体 (PHP 変数の格納に使用される C の組み込みデータ構造体) に格納されている既知の文字列長を返すだけなので、非常に高速に実行されます。ただし、strlen() は関数であるため、関数呼び出しは小文字などの多くの手順を経るため、多少遅くなります (注釈: 小文字の関数名を指します。PHP は関数名の大文字と小文字を区別しません)。 )、ハッシュ検索、呼び出された関数と一緒に実行されます。場合によっては、 isset() トリックを使用してコードの実行を高速化できます。
(下記例)
if (strlen($foo)
(以下のヒントと比較してください)
if (!isset($foo{5})) { echo 「Foo は短すぎます」$$ }
isset() の呼び出しは、strlen() よりも高速です。これは、後者とは異なり、言語構造としての isset() の実行に関数の検索や小文字が必要ないためです。つまり、実際には、最上位コードで文字列の長さをチェックするオーバーヘッドはそれほどかかりません。
34. 変数 $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. mod_zip を Apache モジュールとして使用すると、データを即座に圧縮し、データ送信量を 80% 削減できます。
43. file、fopen、feof、fgets などの一連のメソッドの代わりに file_get_contents を使用できる場合は、より効率的な file_get_contents を使用してください。ただし、URL ファイルを開くときは、file_get_contents の PHP バージョンの問題に注意してください。
44. PHP のファイル操作効率は低くありませんが、ファイル操作をできるだけ少なくします。
45. Select SQL ステートメントを最適化し、実行する挿入操作と更新操作をできるだけ少なくします (更新について批判されました)。46. 可能な限り PHP の内部関数を使用します (ただし、PHP に存在しない関数を見つけるために、カスタム関数を作成できたはずの時間を無駄にしました。
);47. ループ内で変数、特に大きな変数、オブジェクトを宣言しないでください (これは PHP だけの問題ではないようです)
48. 多次元配列で代入をループしたり入れ子にしたりしないようにしてください
49. PHP の内部文字列操作関数を使用できる場合は、正規表現を使用しないでください
50. foreach の方が効率的です。while や for ループの代わりに foreach を使用してみてください
51. 文字列を引用するには二重引用符の代わりに一重引用符を使用します
52. i=i+1 の代わりに i+=1 を使用します。 C/C++の習慣に準拠しており、非常に効率的です
53. グローバル変数の場合は、使用後に unset() する必要があります
コード最適化の例
関数内で配列を渡すとき
return を使用すると、global を使用するより効率的です
たとえば
関数 userloginfo($usertemp){
$detail を返します;
}
$login=userloginfo($userdb);
より良い
関数 userloginfo($usertemp){
グローバル $detail;
$detail=explode("|",$usertemp);
}
ユーザーログ情報($userdb);
効率的になる
2、(このコードはプログラムディレクトリに対応するURLを取得するために使用されます、推奨)
$urlarray=explode(@#/@#,$HTTP_SERVER_VARS[@#REQUEST_URI@#]);
$urlcount=count($urlarray);unset($urlarray[$urlcount-1]);
$ofstarurl=@#http://@#.$HTTP_SERVER_VARS[@#HTTP_HOST@#].implode(@#/@#,$urlarray);
このコードは
$pre_urlarray=explode(@#/@#,$HTTP_SERVER_VARS[@#HTTP_REFERER@#]);
$pre_url=array_pop($pre_urlarray);
効率的になる
3. ループで判定する場合は、数値判定を行うよりも恒等を使用する方が効率的です
$a=2;$b=2;
たとえば
if($a==$b)$c=$a;
より
if($a===$b)$c=$a;
効率的
4. mysql をクエリするときは、where in を使用し、制限を少なくしてください
連続レコードをクエリする場合、非連続レコードの最初の実行は少し遅くなりますが、その後は速くなります
5、NTサーバーのデータ動作の安定性はunix/linuxほど良くありません
6. 出力の前に ob_start() を使用すると、出力が高速化されます。unlix サーバーの場合、ob_start(@#ob_gzhandler@#) を使用すると出力効率が向上します。もっと高い
7. 判断するときは、if($a==his value) を使用してください。負の場合は、if(empty($a)) を使用してください。この方法の方がプログラムが高速に実行されます。
8. 不均等時間を使用する場合、 != は <>と同じくらい効率的です
9. 個人的な経験から言えば、$a="11111111111111"; を使用した場合の効率は、本に書かれているほど違いはありません。10. 標準化された SQL ステートメントを使用すると、MySQL の解析が容易になります
11、
を使用しますコードは次のとおりです | コードをコピー |
if($online){ COOKIEはすぐに有効になります if($online) |
COOKIE を有効にするには、再度更新する必要があります
12、
を使用しますコードは次のとおりです | コードをコピー |
$handle=fopen($filename,wb); より良い ファイル($ファイル名); |
スピードと安定性の両方に優れています
13、切り詰め文字列最適化機能(?文字の出現を回避可能)
コードは次のとおりです | コードをコピー |
関数 substrs($content,$length) {
|
14、プログラム内のケースシールド
コードは次のとおりです | コードをコピー |
($asc=65;$asc
{ //strto lower() この関数は一部のサーバーで文字化けを生成します! if (strrpos($regname,chr($asc))!==false) { $error="ユーザー名での混乱を避けるため、ユーザー名では大文字は禁止されています。小文字を使用してください。"; $reg_check=0; } } |
15、配列関数を取得するために file(); や fget() を使用しないでください。
コードをコピー | |
{ $handle=@fopen($filename,$method); @flock($handle,LOCK_SH); @$filedata=fread($handle,filesize($filename)); @fclose($handle); $filedata=str_replace(" "," $filedb=explode(" //array_pop($filedb); $count=count($filedb); if($filedb[$count-1]==@#){unset($filedb[$count-1]);} $filedb を返します; } |
コードは次のとおりです | コードをコピー |
foreach($tempArray as $row){ array1[$row['ID']] = $row['Key']; array2[$row['Key']][] = $row; } 訪問 |
および処理コード
コードは次のとおりです | コードをコピー |
foreach($array1 as $ID => $Key){ $this->doSomeThing($ID); //tempArrayのブロック配列にアクセス $array2[$Key] $this->doSomeThing2($array2[$Key]); } |