NodeJS-fs文件系统底层操作
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了NodeJS-fs文件系统底层操作相关的知识,希望对你有一定的参考价值。
参考技术A 文件 I/O 是由简单封装的标准 POSIX 函数提供的。 通过 require(\'fs\') 使用该模块,所有的方法都有异步和同步的形式。
异步形式始终以完成回调作为它最后一个参数,传给完成回调的参数取决于具体方法,但第一个参数总是留给异常,如果操作成功完成,则第一个参数会是 null 或 undefined。
当使用同步形式时,任何异常都会被立即抛出。 可以使用 try/catch 来处理异常,或让它们往上冒泡。
异步方法不保证执行顺序。 所以下面的例子容易出错:
fs.stat 可能在 fs.rename 之前执行,正确的方法是把回调链起来。
推荐开发者使用这些函数的异步版本。 同步版本会阻塞整个进程,直到它们完成(停止所有连接)。
【fs.open(path, flags[, mode], callback)】参数如下:
flags可以是:
[注意]使用\'rs+\'模式不会使fs.open()进入同步阻塞调用。如果那是你想要的,则应该使用fs.openSync()。
文件的回调函数中的第二个参数fd代表文件标识,与定时器标识类似,用于标识文件,且随着文件的打开顺序递增。
【fs.openSync(path, flags[, mode])】
fs.open() 的同步版本。 返回一个表示文件描述符的整数。
【fs.read(fd, buffer, offset, length, position, callback)】参数如下:
由于使用read()方法,会将文件内容读取buffer对象中,所以需要提前先准备一个buffer对象。
【fs.readSync(fd, buffer, offset, length, position)】
fs.read() 的同步版本,返回 bytesRead 的数量
【fs.write(fd, buffer, offset, length[, position], callback)】参数如下:
[注意]多次对同一文件使用fs.write且不等待回调,是不安全的。对于这种情况,强烈推荐使用 fs.createWriteStream。
当我们要对打开的文件进行写操作的时候,打开文件的模式应该是读写模式。
【fs.write(fd, data[, position[, encoding]], callback)】
该方法写入data到fd指定的文件。如果data不是一个Buffer实例,则该值将被强制转换为一个字符串。
不同于写入 buffer,该方法整个字符串必须被写入。不能指定子字符串,这是因为结果数据的字节偏移量可能与字符串的偏移量不同。
【fs.writeSync()】
fs.write() 的同步版本,返回写入的字节数。
【fs.close(fd, callback)】参数如下:
一个文件被操作后,要及时将该文件关闭
【fs.closeSync(fd)】
fs.close(fd, callback)的同步版本,返回undefined
java如何实现一次编译到处运行
JVM是一个java虚拟机,所谓的java虚拟机就是和普通的虚拟机一样,拥有自己的CPU,RAM之类的。我们所使用的操作系统是Windows的操作系统,Windows操作系统支持的可执行文件是EXE文件,也就是说在Windows的操作系统上只有EXE的文件是可以直接被操作系统解释为底层机器语言并进行运行的。而java虚拟机可以支持的是.class的可执行文件,在java的虚拟机中遇到.class的文件就可以直接翻译成java虚拟机所能是别的底层机器语言并进行执行。这就是JVM的机制,正是因为java的这种机制才实现了java的跨平台,在不同的平台上安装能够在相应平台上运行的虚拟机,然后在java虚拟机中运行java的源程序,“一次编译,多次执行”就此实现了。所以java的跨平台是离不开虚拟机的支持的。虚拟机充当着java源程序和操作系统之间的中间,不同的操作系统只需要寻找相应的中介就可以实现在不同的操作系统上运行。而java的编译只是吧.java文件编译为.class字节码文件而已,然后把字节码交给虚拟机去执行。
虚拟机在执行的时候是读一句字节码文件人后解释一句给操作系统听,这就是为什么java是解释型的语言。
所谓的编译型的语言是指这种语言被编译之后生成的是可以直接供操作系统执行的010101文件,像C,C++都是编译型的,java因为中间有JVM这么个东西所以是解释型的。 参考技术A 一次编译到处运行指的是用 java开发的程序,用javac命令编译后,在不同电脑,不同操作系统上,只要你装了JVM(java虚拟机),就能运行,但在实际情况中,由于jdk版本有好几个,OracleJDK、IBMJDK、OpenJDK ,兼容性上并不能做到完美,因此,只能做到一次编译,广泛运行。
你的问题是如何实现,我觉得考虑这个意义不大,无论使用的是哪种jdk,一般都能做到兼容的本回答被提问者和网友采纳 参考技术B
JAVA之所以能实现 一次编译,到处运行,是因为JAVA在每个系统平台上都有 JAVA虚拟机(JVM),JAVA编译的中间文件class是由JAVA虚拟机在运行时动态转换为对应平台的机器代码.
Java是一种可以撰写跨平台应用程序的面向对象的程序设计语言。Java 技术具有卓越的通用性、高效性、平台移植性和安全性,广泛应用于PC、数据中心、游戏控制台、科学超级计算机、移动电话和互联网,同时拥有全球最大的开发者专业社群。
Java 由四方面组成:
Java编程语言,即语法。
Java文件格式,即各种文件夹、文件的后缀。
Java虚拟机(JVM),即处理*.class文件的解释器。
Java应用程序接口(Java API)。
主要是通过一个叫java虚拟机的程序实现的
所有java编译后的程序都需要运行在java虚拟机中,虚拟机是操作系统的再抽象,只解析运行字节码
因为生成的字节码和操作系统无关,而虚拟机执行的又是字节码,所有可以跨平台
以上是关于NodeJS-fs文件系统底层操作的主要内容,如果未能解决你的问题,请参考以下文章