中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

PHP中fwrite與file_put_contents性能測試代碼

function microtimeFloat() {
    list($usec,$sec) = explode(" ", microtime());
    return((float)$usec + (float)$sec);
}

1.測試file_put_contents

復制代碼 代碼如下:
<?php
$userCount = 1000;
$itemCount = 1000;
$file = 'ratings.txt';
file_exists($file) &&unlink($file);

$timeStart = microtimeFloat();
for ($i = 0; $i < $userCount; $i++) {
    $uid =random(32);
    for ($j = 0;$j < $itemCount; $j++) {
       $itemId = mt_rand(1, 300000);
       $rating = $j == 0 ? 1 : mt_rand(1, 100) / 100;
       $line = sprintf("%s,%d,%s/n", $uid, $itemId, $rating);
       file_put_contents($file, $line, FILE_APPEND);
    }
}
$timeEnd = microtimeFloat();
echo sprintf("Spend time: |%s| second(s)/n", $timeEnd -$timeStart);
?>

測試結果:
測試過程中出現了打開文件的錯誤,而且程序執行完成以后寫入的數據不完整,只有999997行,漏了3行。最重要的一點是時間花了307秒多,而用fwrite只花了10秒多的時間,差距還是不小的。

D:/myphp/research>php test2.php
php Warning: file_put_contents(ratings.txt): failed to open stream:Permission
denied in D:/myphp/research/test2.php on line 79

Warning: file_put_contents(ratings.txt): failed to open stream:Permission denie
d in D:/myphp/research/test2.php on line 79
Spend time: |307.0586669445|second(s)

...
999994:98xDtLjaeD8MG9ywifegZvRRQzVBZbbw,167670,0.15
999995:98xDtLjaeD8MG9ywifegZvRRQzVBZbbw,234223,0.13
999996:98xDtLjaeD8MG9ywifegZvRRQzVBZbbw,84947,0.79
999997:98xDtLjaeD8MG9ywifegZvRRQzVBZbbw,6489,0.38

2.測試fwrite

復制代碼 代碼如下:
<?php
$userCount = 1000;
$itemCount = 1000;
$file = 'ratings.txt';
file_exists($file) &&unlink($file);

$fp = @fopen($file, 'ab');
if (!$fp) die("Open $file failed");

$timeStart = microtimeFloat();
for ($i = 0; $i < $userCount; $i++) {
    $uid =random(32);
    for ($j = 0;$j < $itemCount; $j++) {
       $itemId = mt_rand(1, 300000);
       $rating = $j == 0 ? 1 : mt_rand(1, 100) / 100;
       $line = sprintf("%s,%d,%s/n", $uid, $itemId, $rating);
       fwrite($fp, $line);
       $k++;
    }
}
if ($fp) @fclose($fp);
$timeEnd = microtimeFloat();
echo sprintf("Spend time: |%s| second(s)/n", $timeEnd -$timeStart);
?>

測試結果:
寫一百萬行記錄,10秒左右寫完,對于php來說,速度算不錯了。這是在我的個人電腦上面測試的,如果在生產機上測試,可能速度還要快一些。
D:/myphp/research>php test2.php
Spend time: |10.764221191406|second(s)

用fwrite寫入的數據是完整的
999997,QOvcZYFJFlFHjiGyGxAc615kOXdX3Yii,246982,0.03
999998,QOvcZYFJFlFHjiGyGxAc615kOXdX3Yii,240160,0.39
999999,QOvcZYFJFlFHjiGyGxAc615kOXdX3Yii,46296,0.61
1000000,QOvcZYFJFlFHjiGyGxAc615kOXdX3Yii,26211,0.14

3.總結
如果要往文件里面寫入大量的數據,則推薦用fwrite,不要用file_put_contents。在高并發的請求中也建議用fwrite。

php技術PHP中fwrite與file_put_contents性能測試代碼,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲一区二区中文字幕 | 亚洲欧美日韩电影 | 在线一区观看 | 久久99精品久久久 | 亚洲午夜一区二区 | 欧美二区三区 | 日韩精品免费看 | 精品久久久久久久久久 | 精品久久久久久久久久久久 | 亚洲精品99| 久草久草久草 | 国产人成精品一区二区三 | 九九久久久 | 国产欧美在线一区 | 国产精品激情在线 | 丝袜美腿一区二区三区动态图 | 男女下面一进一出网站 | 欧美精品在线观看 | 色婷婷精品久久二区二区蜜臂av | 91影视| 日韩精品一区二 | 久久国产欧美日韩精品 | 中文字幕日韩一区 | 久久国产精品99久久久大便 | 一区二区三区国产在线观看 | 日韩欧美二区 | 久久激情视频 | av毛片在线免费观看 | 亚洲欧美日韩中文在线 | 91精品久久久久久久久久入口 | 日本三级网站在线 | 在线小视频 | 国产乱码精品一品二品 | 国产激情三区 | 在线欧美一区 | 久久99精品久久久久 | 中文字幕成人av | 亚洲精品一区二区在线 | 91久久国产| 亚洲高清在线观看 | 日韩日韩日韩日韩日韩日韩日韩 |