激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - PHP教程 - PHP中fwrite與file_put_contents性能測試代碼

PHP中fwrite與file_put_contents性能測試代碼

2020-05-13 14:50PHP教程網 PHP教程

這里測試的是往文件中寫一百萬行記錄,如果數據量很小,比如1000條左右的記錄,可能差距不大

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。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲性生活免费视频 | 国产精品免费一区二区三区在线观看 | 国产亚洲精品综合一区91555 | 91精品免费观看 | 五月激情久久 | 钻石午夜影院 | 草久影院 | 欧美激情区 | 欧美精品一区二区中文字幕 | 国产毛片网 | 伊人yinren22综合网色 | 一级毛片免费观看在线 | 韩国19禁在线 | 日日操夜 | 欧美性黄| 欧美视频一区二区三区四区 | 一本一本久久a久久精品综合小说 | 在线观看免费毛片视频 | 看免费一级毛片 | 爱操av | 国产精品久久久久久影院8一贰佰 | 97超视频在线观看 | 欧美a区| 成人福利视频 | 黄色av电影在线播放 | 2019天天干夜夜操 | 国产精品久久久久国产精品三级 | 9999在线视频 | 欧美日韩一区,二区,三区,久久精品 | 99re热视频这里只精品 | 欧美一级黄色录相 | 黑人日比视频 | av成人在线观看 | 成人精品视频网站 | 久久久久久久久久久久久久久伊免 | 性欧美一区二区 | 免费人成在线播放 | 中文字幕伦乱 | 日本免费一区二区三区四区 | 美女羞羞视频在线观看 | 在线中文资源免费 |