勉強したことのメモ

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

  関連記事

Opauthで「Please change the…」エラーの対応方法

Opauthを使用中に「Notice: Please change the va ...

PHPで定義済みの変数 / 定数とincludeしているファイル一覧を取得する方法

他社が作成されたPHPのファイルを読み解く際に、定義済みの変数 / 定数や、in ...

Stripe Checkoutにてクレジットカード決済の際に3Dセキュア対応にする方法

先日Stripe Checkoutを用いたクレジットカード決済機能についてメモし ...

PHPにてhosts設定を行った上で他サイト・サーバにアクセスする方法

開発中の案件だとhosts設定を行ってサーバにアクセスする、ということがある。作 ...

PHP8系で関数の引数が設定しやすくなる名前付き引数について

PHP8系で名前付き引数が導入されたということを最近知った。今までは「第〇引数」 ...