日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
Node.js中實(shí)現(xiàn)文件的循環(huán)寫(xiě)入

node.js對(duì)所有外部資源調(diào)用提供異步機(jī)制,文件IO也不例外。在這種異步機(jī)制下,進(jìn)程不會(huì)被阻塞,這極大提高了CPU的利用率,為單進(jìn)程的模式奠定了基礎(chǔ)。但同時(shí),異步機(jī)制的引入也給程序邏輯的實(shí)現(xiàn)帶來(lái)了一定復(fù)雜性,原來(lái)一些慣常的思維方式需要進(jìn)行轉(zhuǎn)換。

創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比工布江達(dá)網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式工布江達(dá)網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋工布江達(dá)地區(qū)。費(fèi)用合理售后完善,十年實(shí)體公司更值得信賴。

本文將以一個(gè)文件操作的實(shí)例來(lái)說(shuō)明這一點(diǎn)。

假設(shè)我們需要新建一個(gè)文件,在其中循環(huán)寫(xiě)入0-9的數(shù)字,文件的總長(zhǎng)度為1G bytes。在通常情況下,我們需要建立一個(gè)buffer,將內(nèi)容放入其中,然后打開(kāi)文件,在一個(gè)循環(huán)中多次向文件中寫(xiě)入,直至寫(xiě)滿1G的長(zhǎng)度。在node.js中我們同樣可以使用同步文件寫(xiě)操作(例如 fs.writeSync)來(lái)實(shí)現(xiàn)這個(gè)邏輯,但這樣做顯然無(wú)法利用node.js提供的異步機(jī)制的優(yōu)勢(shì)。寫(xiě)操作會(huì)在fs.writeSync調(diào)用時(shí)阻塞,如果同時(shí)有其他運(yùn)算任務(wù)需要處理,則會(huì)在進(jìn)程中排隊(duì),造成 CPU資源浪費(fèi)。

如果我們使用基于事件回調(diào)的異步文件寫(xiě)操作(例如 fs.write),如何來(lái)模擬同步模式下的循環(huán)邏輯呢?自然可以想到的一點(diǎn)是定義一個(gè)函數(shù)用來(lái)處理單次寫(xiě)入操作,然后依靠事件回調(diào)反復(fù)調(diào)用此函數(shù),直至寫(xiě)滿計(jì)劃中的長(zhǎng)度。但問(wèn)題在于回調(diào)函數(shù)的參數(shù)形式是固定的,無(wú)法加入fd (file descriptor)和循環(huán)變量來(lái)標(biāo)注當(dāng)前運(yùn)行的進(jìn)度狀況。解決這個(gè)問(wèn)題,我們可以應(yīng)用js語(yǔ)言中的“閉包”機(jī)制,因?yàn)殚]包函數(shù)可以在棧中保存定義此函數(shù)的現(xiàn)場(chǎng)。

具體代碼如下:

 
 
 
  1. var file_size = 1024*1024*1024;         //1G  
  2. var buf_size = 10240;  
  3.  
  4. var fs = require('fs');  
  5. var buf = new Buffer(buf_size);  
  6.  
  7. // init temp buffer  
  8. var temp = new Buffer(10);  
  9. for (var i=0; i<10; i++) {  
  10.     temp[i] = (i).toString().charCodeAt(0);  
  11. }  
  12.  
  13. // init buf  
  14. for (var i=0; i
  15.     temp.copy(buf, 10*i);  
  16. }  
  17. temp.copy(buf, 10*i, 0, buf_size-parseInt(buf_size/10)*10);  
  18.  
  19. // write to file  
  20. fs.open('big.block', 'w', 0666, function(err, fd){  
  21.     if (err) throw err;  
  22.  
  23.     function write(err, written) {  
  24.         if (err) throw err;  
  25.         if (i>=file_size/buf_size) {    //close the file  
  26.             fs.close(fd);  
  27.         } else {            //continue to write  
  28.             var length = buf_size;  
  29.             if ((i+1)*buf_size>file_size) {  
  30.                 length = file_size-i*buf_size;  
  31.             }  
  32.             fs.write(fd, buf, 0, length, null, write);  
  33.             i++;  
  34.         }  
  35.     }  
  36.  
  37.     var i=0;  
  38.     write(null, 0);  
  39. }); 

需要注意緩沖區(qū)大小對(duì)寫(xiě)操作的性能影響很大。過(guò)小的緩沖區(qū)會(huì)造成從磁盤(pán)到文件系統(tǒng),甚至用戶程序,整個(gè)過(guò)程更大的資源消耗,從而影響程序的執(zhí)行效率。通過(guò)time數(shù)據(jù)可明顯觀察到其差別:

1K緩沖:

real 0m39.340s

user 0m18.244s

sys 0m34.750s

10K緩沖:

real 0m7.985s

user 0m2.037s

sys 0m7.525s

100K緩沖:

real 0m4.223s

user 0m0.312s

sys 0m4.077s

原文:http://cnodejs.org/blog/?p=168#comment-820


分享題目:Node.js中實(shí)現(xiàn)文件的循環(huán)寫(xiě)入
分享URL:http://m.5511xx.com/article/dhsissh.html