勉強したことのメモ

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でeval実行時に「eval()'d code on line」エラー

PHPでeval実行時に「eval()'d code on line 〇〇」とい ...

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

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

MySQLで直近に挿入したオートインクリメントの値と次回挿入する値を取得する方法

phpとmysqliを使っている中で次回挿入するオートインクリメントの値と、前回 ...

PHPでBlowfishアルゴリズムを用いた暗号化と復号化方法

PHPでBlowfishアルゴリズムを用いてCBCモードで暗号化と復号化を行いた ...

PHPでルーティング用ライブラリ「AltoRouter」の利用方法

PHPフレームワークのCodeIgniterを勉強していた際にルーティング機能が ...