首頁 後端開發 php教程 php pthreads 多线程扩展的使用:一个较为稳定例子。

php pthreads 多线程扩展的使用:一个较为稳定例子。

Jun 23, 2016 pm 01:29 PM

今天研究了worker stackable的配合方法,写了两种形式,虽然能工作,但是都会出现内存不听增长的问题;

于是把第一个方法的代码邮件给了作者,到现在他没有回复我。

 

我最后放弃两者配合的方式,直接使用worker,发现到现在执行了582000个工作,内存没有增长,速度也基本稳定,代码如下:

[php] view plain copy print ?

shift()){                   $data_flag = true;                   $this->doSomeWork();                   if((++$count)%1000==0){                       printf("Work Mermory used %.3fMB RAM, time: %3f===> %d \n",                         memory_get_peak_usage(true)/1048576, (microtime(true) - $stime), $count);                       $stime = microtime(true);                   }               }else{                   usleep(100000);               }           }                  exit;       }       private function doSomeWork(){           $str = 'sdalsadkfkasd;lfksa;ldfkas;lkf;lsadkf;as';           $len = strlen($str);                      $s = substr($str,rand(0,$len));           $len = floor(strlen($s)/2);                      for($i=0;$istart();      $stime = microtime(true);   $count = 3000000;//99999999;   $total = $count*5;      $ct = 0;   while($count--){       //for ($target = 0; $target 


 

虚拟上的运行速度:

[plain] view plain copy print ?

Work Mermory used 0.250MB RAM, time: 2.141709===> 607000    Work Mermory used 0.250MB RAM, time: 1.721918===> 608000    Work Mermory used 0.250MB RAM, time: 1.858363===> 609000    Work Mermory used 0.250MB RAM, time: 1.734542===> 610000    Work Mermory used 0.250MB RAM, time: 1.819794===> 611000    Work Mermory used 0.250MB RAM, time: 1.847132===> 612000    Work Mermory used 0.250MB RAM, time: 1.740353===> 613000    Work Mermory used 0.250MB RAM, time: 1.628364===> 614000    Work Mermory used 0.250MB RAM, time: 1.731518===> 615000    Work Mermory used 0.250MB RAM, time: 1.730583===> 616000    Work Mermory used 0.250MB RAM, time: 1.825315===> 617000    Work Mermory used 0.250MB RAM, time: 1.762334===> 618000    Work Mermory used 0.250MB RAM, time: 1.842860===> 619000    Work Mermory used 0.250MB RAM, time: 1.732677===> 620000  
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

11個最佳PHP URL縮短腳本(免費和高級) 11個最佳PHP URL縮短腳本(免費和高級) Mar 03, 2025 am 10:49 AM

11個最佳PHP URL縮短腳本(免費和高級)

Instagram API簡介 Instagram API簡介 Mar 02, 2025 am 09:32 AM

Instagram API簡介

在Laravel中使用Flash會話數據 在Laravel中使用Flash會話數據 Mar 12, 2025 pm 05:08 PM

在Laravel中使用Flash會話數據

構建具有Laravel後端的React應用程序:第2部分,React 構建具有Laravel後端的React應用程序:第2部分,React Mar 04, 2025 am 09:33 AM

構建具有Laravel後端的React應用程序:第2部分,React

簡化的HTTP響應在Laravel測試中模擬了 簡化的HTTP響應在Laravel測試中模擬了 Mar 12, 2025 pm 05:09 PM

簡化的HTTP響應在Laravel測試中模擬了

php中的捲曲:如何在REST API中使用PHP捲曲擴展 php中的捲曲:如何在REST API中使用PHP捲曲擴展 Mar 14, 2025 am 11:42 AM

php中的捲曲:如何在REST API中使用PHP捲曲擴展

在Codecanyon上的12個最佳PHP聊天腳本 在Codecanyon上的12個最佳PHP聊天腳本 Mar 13, 2025 pm 12:08 PM

在Codecanyon上的12個最佳PHP聊天腳本

宣布 2025 年 PHP 形勢調查 宣布 2025 年 PHP 形勢調查 Mar 03, 2025 pm 04:20 PM

宣布 2025 年 PHP 形勢調查

See all articles