fs模块-fs.open(path, flags[, mode], callback)异步地打开文件和fs.openSync(path, flags[, mode])同步打开文件返回文件描述符

fs.open(path, flags[, mode], callback)

  • path string | Buffer | URL
  • flags string | number
  • mode integer Default: 0o666
  • callback Function
    – err
    – fd 文件描述符

异步地打开文件。 flags 可以是:

‘r’ - 以读取模式打开文件。如果文件不存在则发生异常。

‘r+’ - 以读写模式打开文件。如果文件不存在则发生异常。

‘rs+’ - 以同步读写模式打开文件。命令操作系统绕过本地文件系统缓存。

这对 NFS 挂载模式下打开文件很有用,因为它可以让你跳过潜在的旧本地缓存。 它对 I/O 的性能有明显的影响,所以除非需要,否则不要使用此标志。

注意,这不会使 fs.open() 进入同步阻塞调用。 如果那是你想要的,则应该使用 fs.openSync()。

‘w’ - 以写入模式打开文件。文件会被创建(如果文件不存在)或截断(如果文件存在)。

‘wx’ - 类似 ‘w’,但如果 path 存在,则失败。

‘w+’ - 以读写模式打开文件。文件会被创建(如果文件不存在)或截断(如果文件存在)。

‘wx+’ - 类似 ‘w+’,但如果 path 存在,则失败。

‘a’ - 以追加模式打开文件。如果文件不存在,则会被创建。

‘ax’ - 类似于 ‘a’,但如果 path 存在,则失败。

‘a+’ - 以读取和追加模式打开文件。如果文件不存在,则会被创建。

‘ax+’ - 类似于 ‘a+’,但如果 path 存在,则失败。

mode 可设置文件模式(权限和 sticky 位),但只有当文件被创建时才有效。默认为 0o666,可读写。

该回调有两个参数 (err, fd)。

特有的标志 ‘x’(在 open(2) 中的 O_EXCL 标志)确保 path 是新创建的。 在 POSIX 操作系统中,path 会被视为存在,即使是一个链接到一个不存在的文件的符号。 该特有的标志有可能在网络文件系统中无法使用。

flags 也可以是一个数字,[open(2)] 文档中有描述; 常用的常量可从 fs.constants 获取。 在 Windows 系统中,标志会被转换为与它等同的替代者,例如,O_WRONLY 转换为 FILE_GENERIC_WRITE、或 O_EXCL|O_CREAT 转换为 CREATE_NEW,通过 CreateFileW 接受。

在 Linux 中,当文件以追加模式打开时,定位的写入不起作用。 内核会忽略位置参数,并总是附加数据到文件的末尾。

注意:fs.open() 某些标志的行为是与平台相关的。 因此,在 macOS 和 Linux 下用 ‘a+’ 标志打开一个目录(见下面的例子),会返回一个错误。 与此相反,在 Windows 和 FreeBSD,则会返回一个文件描述符。

// macOS 与 Linux
fs.open('<directory>', 'a+', (err, fd) => {
  // => [Error: EISDIR: illegal operation on a directory, open <directory>]
});

// WindowsFreeBSD
fs.open('<directory>', 'a+', (err, fd) => {
  // => null, <fd>
});

fs.openSync(path, flags[, mode])

  • path string | Buffer | URL
  • flags string | number
  • mode integer Default: 0o666

fs.open() 的同步版本。 返回一个表示文件描述符的整数。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值