我在两个步骤中使用了带有nodejs的write文件:
1.首先判断文件是否存在,使用fs.exists功能;
然后fs.writeFile直接用来写文件;
但是现在我注意到有更多的函数用于写文件,比如fs.open或者fs.close,我应该在写入时使用这些函数来打开还是关闭文件?
此外,我注意到有有fs.createReadStream和fs.createWriteStream功能,什么是它们之间的差异fs.writeFile和fs.readFile?
ben*_*y23 29
以下是我将如何解释这些差异:
低级别:
fs.open和fs.close处理文件描述符.这些是低级函数,表示打开(2) BSD系统调用的映射调用.由于您将拥有文件描述符,因此您将使用fs.read或fs.write.
注意,所有这些都是异步的,并且还有同步版本:fs.openSync,fs.closeSync,fs.readSync,fs.writeSync,您不会使用回调.异步和同步版本之间的区别fs.openSync仅在于打开文件的操作完成时才会返回,而fs.open直接返回则会在回调中使用文件描述符.
这些低级功能可以让您完全控制,但意味着更多的编码.
中级:
fs.createReadStream和fs.createWriteStream创建可以连接到事件的流对象.这些事件的示例是"数据"(当读取了一大块数据,但该块只是文件的一部分时)或"关闭".这样做的好处是,您可以读取文件并在数据进入时对其进行处理,即您不必读取整个文件,将其保存在内存中然后进行处理.这在处理大型文件时很有意义,因为您可以在处理块中的位时获得更好的性能,而不是处理整个文件(例如,内存中的整个1GB文件).
高水平:
fs.readFile和fs.writeFile对整个文件进行操作.所以你打电话fs.readFile,节点将读入整个文件,然后在你的回调中显示整个数据.这样做的好处是您不需要处理不同大小的块(比如使用流时).写入时,node会写入整个文件.这种方法的缺点是,在读/写时,您必须将整个文件放在内存中.例如,如果要转换日志文件,则可能只需要数据行,使用流可以执行此操作,而无需等待文件在开始写入之前完全读取.
还有fs.readFileSync和fs.writeFileSync,它们不会使用回调,而是在返回之前等待读/写完成.使用它的优点是,对于一个小文件,您可能不希望在文件返回之前执行任何操作,但对于大文件,这意味着CPU在等待文件I/O完成时会空闲.
希望有意义并回答你的问题,在使用时fs.writeFile你不需要fs.open或fs.close.