成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Node.js中實現文件的循環寫入

開發 前端
node.js對所有外部資源調用提供異步機制,文件IO也不例外。在這種異步機制下,進程不會被阻塞,這極大提高了CPU的利用率,為單進程的模式奠定了基礎。

node.js對所有外部資源調用提供異步機制,文件IO也不例外。在這種異步機制下,進程不會被阻塞,這極大提高了CPU的利用率,為單進程的模式奠定了基礎。但同時,異步機制的引入也給程序邏輯的實現帶來了一定復雜性,原來一些慣常的思維方式需要進行轉換。

本文將以一個文件操作的實例來說明這一點。

假設我們需要新建一個文件,在其中循環寫入0-9的數字,文件的總長度為1G bytes。在通常情況下,我們需要建立一個buffer,將內容放入其中,然后打開文件,在一個循環中多次向文件中寫入,直至寫滿1G的長度。在node.js中我們同樣可以使用同步文件寫操作(例如 fs.writeSync)來實現這個邏輯,但這樣做顯然無法利用node.js提供的異步機制的優勢。寫操作會在fs.writeSync調用時阻塞,如果同時有其他運算任務需要處理,則會在進程中排隊,造成 CPU資源浪費。

如果我們使用基于事件回調的異步文件寫操作(例如 fs.write),如何來模擬同步模式下的循環邏輯呢?自然可以想到的一點是定義一個函數用來處理單次寫入操作,然后依靠事件回調反復調用此函數,直至寫滿計劃中的長度。但問題在于回調函數的參數形式是固定的,無法加入fd (file descriptor)和循環變量來標注當前運行的進度狀況。解決這個問題,我們可以應用js語言中的“閉包”機制,因為閉包函數可以在棧中保存定義此函數的現場。

具體代碼如下:

  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<buf_size/10-1; 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. }); 

需要注意緩沖區大小對寫操作的性能影響很大。過小的緩沖區會造成從磁盤到文件系統,甚至用戶程序,整個過程更大的資源消耗,從而影響程序的執行效率。通過time數據可明顯觀察到其差別:

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

【編輯推薦】

  1. Node.js源碼研究之模塊組織加載
  2. 淺析Node.js中的流程控制
  3. 揭秘Node.js事件
  4. Node.js初探之hello world
  5. 什么是Node.js?
責任編輯:陳貽新 來源: cnodejs.org
相關推薦

2024-01-05 08:49:15

Node.js異步編程

2012-02-03 09:25:39

Node.js

2021-05-27 09:00:00

Node.js開發線程

2023-01-31 16:43:31

?Node.js事件循環

2021-01-04 08:09:58

Node.js磁盤接口

2021-10-22 08:29:14

JavaScript事件循環

2014-09-12 10:35:09

Node.jsHTTP 206

2021-12-18 07:42:15

Ebpf 監控 Node.js

2021-05-21 09:36:42

開發技能代碼

2016-08-11 14:02:02

NodeJS前端

2020-04-15 15:48:03

Node.jsstream前端

2013-11-01 09:34:56

Node.js技術

2015-03-10 10:59:18

Node.js開發指南基礎介紹

2017-03-19 16:40:28

漏洞Node.js內存泄漏

2017-03-20 13:43:51

Node.js內存泄漏

2022-01-11 17:23:12

配置Node.jsNode

2021-12-25 22:29:57

Node.js 微任務處理事件循環

2020-05-29 15:33:28

Node.js框架JavaScript

2021-06-10 07:51:07

Node.js循環機制

2021-07-16 04:56:03

NodejsAddon
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 午夜在线影院 | 亚洲一区在线播放 | 欧美淫片| 一区二区三区在线观看免费视频 | 91极品欧美视频 | 欧美激情视频一区二区三区在线播放 | 国产在线一区二区三区 | 91精品久久久久久久99 | 亚洲精品乱码久久久久久9色 | 91在线第一页 | 看一级毛片视频 | 日本不卡一区二区三区在线观看 | 国产精品178页 | 日本在线观看视频 | 国产一区二区三区四区在线观看 | 欧美日韩久久久久 | 色桃网 | 欧美日韩亚洲国产综合 | 免费人成激情视频在线观看冫 | www..com18午夜观看 | 中文字幕免费 | 美女福利网站 | 麻豆视频在线免费观看 | 在线观看亚 | 自拍视频国产 | 日韩欧美在线观看视频 | 欧美日韩综合精品 | 久久精品免费一区二区 | 亚洲欧美v | 亚洲精品日本 | 国产精品久久久久无码av | 国产日韩一区二区三免费高清 | 亚洲精品1区 | 久久久久久亚洲 | aaa综合国产 | 久久精品一区二区三区四区 | 一二区成人影院电影网 | 18性欧美 | 九九热精品免费 | 国产精品综合 | 国内91在线 |