@H_403_0@在前文中,提到了一个概念,就是当我在读取文件时,我需要知道这个文件的数据量的大小,而在readFile的源码中,是使用的fa.fstat方法,获取到了文件的相关数据,而对于使用fstat获取到的一个对象中,所包含的属性和方法代表的具体含义,前文中并没有涉及,本篇就看下,这个State对象中,包含的数据都有哪些,并且他们分别代表的含义是什么。
@H_403_0@
方法集合
@H_403_0@方法集合,不是说的State对象中包含的方法集合,而是说,在调用哪些API时,返回的值时一个State的实例,比如,在fstate就是其中之一。 @H_403_0@其他方法集合包括:
- fs.fstat
- fs.lstat
- fs.stat
fs.lstat(path,callback);
//传入的参数是目录的路径,和回调函数
fs.fstat(fd,callback);
//传入的参数是文件描述符,和回调函数
//所以,该方法在readFile时,在open打开文件成功之后,才使用。
callback(err,stats){
//回调函数的参数是相同的,第一个参数为错误对象,包含错误信息
//第二个参数,也就是本篇文章的重点,为一个State对象的实例,包含对应文件的或者目录的相关信息
}
State对象的源码
@H_403_0@这里没有在继续给实例,是因为,在我看来,这里只是一些属性和方法的集合,如果需要,直接调用即可,所以没有什么用法的差异。 @H_403_0@先看源码,在源码中,注释每一个属性的代表含义(该部分源自“Nodejs权威指南”)。this.mode = mode;
//和之前在write时的mode<a href="/tag/shuxing/" target="_blank" class="keywords">属性</a>相同,为<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>的权限标志,数字形式
this.nlink = nlink;
//<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>或目录的硬连接数,类似于一个<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>的别名,使用fs.link创建,使用fs.unlink<a href="/tag/shanchu/" target="_blank" class="keywords">删除</a>,
//我这里不太理解这个存在的意义,所以接下来也不会有这个相关的<a href="/tag/neirong/" target="_blank" class="keywords">内容</a>
this.uid = uid;
//uid为<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>或者目录的所有者的<a href="/tag/yonghu/" target="_blank" class="keywords">用户</a>ID,仅在UNIX操作系统有效
this.gid = gid;
//gid为<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>或者目录所有者所在组的ID,仅在UNIX操作系统有效
this.rdev = rdev;
//字符设备<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>或者块设备<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>所在的设备ID,仅在UNIX操作系统有效
this.blksize = blksize;
//没有在任何地方,看到关于该<a href="/tag/shuxing/" target="_blank" class="keywords">属性</a>的描述,源码中
this.ino = ino;
//<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>或者目录的索引编号,仅在UNIX操作系统下有效
this.size = size;
//<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>尺寸,即<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>中的字节数
this.blocks = blocks;
//没有看到相关的介绍
this.atime = new Date(atim_msec);
//<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>数据上次被访问的时间.会被 mknod(2),utimes(2),and read(2) 等系统<a href="/tag/diaoyong/" target="_blank" class="keywords">调用</a>改变。
this.mtime = new Date(mtim_msec);
// <a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>上次被<a href="/tag/xiugai/" target="_blank" class="keywords">修改</a>的时间。 会被 mknod(2),and write(2) 等系统<a href="/tag/diaoyong/" target="_blank" class="keywords">调用</a>改变
this.ctime = new Date(ctim_msec);
//<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>状态上次改变的时间。 (inode data modification).
//会被 chmod(2),chown(2),link(2),mknod(2),rename(2),//unlink(2),read(2),and write(2) 等系统<a href="/tag/diaoyong/" target="_blank" class="keywords">调用</a>改变。
this.birthtime = new Date(birthtim_msec);
// <a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>被创建的时间。 会在<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>被创建时<a href="/tag/shengcheng/" target="_blank" class="keywords">生成</a>。 在一些不提供<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>birthtime的<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>系统中,//这个字段会被 ctime 或 1970-01-01T00:00Z (ie,unix epoch timestamp 0)来填充
};
//属于一个判断各个属性的方法,其他方法,都是基于调用该方法,获取得到的返回值。
fs.Stats.prototype._checkModeProperty = function(property) {
return ((this.mode & constants.S_IFMT) === property);
};
//用于判断被查看的对象是否为一个目录,返回true,false
fs.Stats.prototype.isDirectory = function() {
return this._checkModeProperty(constants.S_IFDIR);
};
//用于判断,被查看的对象是否为一个文件,返回true,false,于isDirectory的返回值相反
fs.Stats.prototype.isFile = function() {
return this._checkModeProperty(constants.S_IFREG);
};
//用于判断被查看的文件时否为一个块设备文件(概念请看源码之后),返回true,false,只在UNIX操作系统有效
fs.Stats.prototype.isBlockDevice = function() {
return this._checkModeProperty(constants.S_IFBLK);
};
//用于判断被查看的文件,是否为一个字符设备文件,返回true,false,只在UNIX系统下有效
//本以为其值与isBlockDevice返回值相反,但是测试了一下,都是返回的false(MAC系统,操作.js的文件),
//可能是有些关系不,暂时不太了解
fs.Stats.prototype.isCharacterDevice = function() {
return this._checkModeProperty(constants.S_IFCHR);
};
//被查看的文件是否为一个符号链接文件,返回true,false,该方法只在lstat的回调函数中有效。
//如果被查看的文件是符合链接文件,那么就认为改符号链接是一个目录,需要使用lstat查看相关的属性才行。
fs.Stats.prototype.isSymbolicLink = function() {
return this._checkModeProperty(constants.S_IFLNK);
};
//查看文件是否为一个FIFO文件,返回true,false,仅在UNIX系统下有效
fs.Stats.prototype.isFIFO = function() {
return this._checkModeProperty(constants.S_IFIFO);
};
//判断一个文件是否为socket文件,返回true,false,仅在UNIX系统下有效。
//话说:有socket文件这种文件?socket文件也可以判断的?
fs.Stats.prototype.isSocket = function() {
return this._checkModeProperty(constants.S_IFSOCK);
};