Node.js中怎么实现文件循环写入

本篇文章给大家分享的是有关Node.js中怎么实现文件循环写入,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

成都创新互联公司是一家集网站建设,安岳企业网站建设,安岳品牌网站建设,网站定制,安岳网站建设报价,网络营销,网络优化,安岳网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。

假设我们需要新建一个文件,在其中循环写入0-9的数字,文件的总长度为1G bytes。在通常情况下,我们需要建立一个buffer,将内容放入其中,然后打开文件,在一个循环中多次向文件中写入,直至写满1G的长度。在node.js中我们同样可以使用同步文件写操作(例如 fs.writeSync)来实现这个逻辑,但这样做显然无法利用node.js提供的异步机制的优势。写操作会在fs.writeSync调用时阻塞,如果同时有其他运算任务需要处理,则会在进程中排队,造成 CPU资源浪费。

如果我们使用基于事件回调的异步文件写操作(例如 fs.write),如何来模拟同步模式下的循环逻辑呢?自然可以想到的一点是定义一个函数用来处理单次写入操作,然后依靠事件回调反复调用此函数,直至写满计划中的长度。但问题在于回调函数的参数形式是固定的,无法加入fd (file descriptor)和循环变量来标注当前运行的进度状况。解决这个问题,我们可以应用js语言中的“闭包”机制,因为闭包函数可以在栈中保存定义此函数的现场。

具体代码如下:

var file_size = 1024*1024*1024;         //1G  var buf_size = 10240;   var fs = require('fs');  var buf = new Buffer(buf_size);   // init temp buffer  var temp = new Buffer(10);  for (var i=0; i<10; i++) {      temp[i] = (i).toString().charCodeAt(0);  }   // init buf  for (var i=0; i=file_size/buf_size) {    //close the file              fs.close(fd);          } else {            //continue to write              var length = buf_size;              if ((i+1)*buf_size>file_size) {                  length = file_size-i*buf_size;              }              fs.write(fd, buf, 0, length, null, write);              i++;          }      }       var i=0;      write(null, 0);  });

需要注意缓冲区大小对写操作的性能影响很大。过小的缓冲区会造成从磁盘到文件系统,甚至用户程序,整个过程更大的资源消耗,从而影响程序的执行效率。通过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

以上就是Node.js中怎么实现文件循环写入,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注创新互联行业资讯频道。


当前题目:Node.js中怎么实现文件循环写入
分享URL:http://pcwzsj.com/article/gssohe.html