勉強したことのメモ

Webエンジニア / プログラマが勉強したことのメモ。

PHPにて特定の処理にかかった時間とメモリ使用量を測定する方法

   2024/04/17  PHP

PHPにて特定の処理にかかった時間とメモリ使用量を測定したい。以下にソースコードをメモ。

 

ソースコード

<?php
//処理開始
$start_time = microtime(true);


/*処理したい内容をここに記述する*/


//処理終了
$end_time = microtime(true);

//処理にかかった時間を計算
$rs = $end_time - $start_time;

//メモリ使用量確認用の関数
function formatBytes( $bytes, $precision = 2, array $units = null ){
    if( abs($bytes) < 1024 ){
        $precision = 0;
    }
    if( is_array($units) === false ){
        $units = array('B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB');
    }
    if( $bytes < 0 ){
        $sign = '-';
        $bytes = abs($bytes);
    }else{
        $sign = '';
    }
    $exp   = floor(log($bytes) / log(1024));
    $unit  = $units[$exp];
    $bytes = $bytes / pow(1024, floor($exp));
    $bytes = sprintf('%.'.$precision.'f', $bytes);
    return $sign.$bytes.' '.$unit;
}

//処理時間とメモリ使用量を出力
echo '処理時間:' . $rs . '秒 / メモリ使用量:' . formatBytes(memory_get_usage());

 

memory_get_usage

http://php.net/manual/ja/function.memory-get-usage.php

 

参考サイト

http://qiita.com/suin/items/0090ab167bbdb3d77181

 - PHP

  関連記事

PHPで土日祝日及び営業時間を考慮した上で翌○営業日を計算する方法

PHPで翌○営業日を計算したい。例えば本日が2021/04/15で翌5営業日を計 ...

PHPでランダムな値を取得したいケース諸々の対応方法

テストデータを作成する際にランダムな値を入れたかったけど、色々ケースがあったので ...

CodeIgniter3でログをファイルに出力する方法

Codeigniter3でエラーログの設定を行い特定のファイルに出力させ当該ログ ...

PHPで配列のキーの最大値を取得する方法

配列のキーに整数値が入っていて、その中から最大値を取得したいケースがあった。調べ ...

Facebookのタイムラインを取得して表示する方法

Facebookのタイムラインを取得してきて、表示させたいという案件があった。 ...