这是我在学习Node.js权威指南时遇到的问题
用open打开文件后用read对文件进行读取并且将读取到的内容存储到缓存buf中。然后把buf中实际读取到的内容输出,并从当前位置进行下一次内容的读取与存储。
fs.open('sample.txt','r',function(err,fd){
var buf = new Buffer(255);
//一个汉字的utf编码为三字节数据
//开始写的位置,读的长度,开始读的位置
fs.read(fd,buf,0,9,3,function(err,bytesRead,buffer){
console.log(buffer.slice(0,bytesRead).toString());
//从文件的当前读取位置继续往下读取
fs.read(fd,buf,0,9,null,function(err,bytesRead,buffer){
console.log(buffer.slice(0,bytesRead).toString())
})
})
})
这是我的sample.txt文件
我喜爱编程
按道理结果应该是
喜爱编
程
但是结果却是
看起来文件没有从当前位置开始读取内容,而是从头进行了读取。
这是为什么呢?我们来看看下面的代码
fs.open('sample.txt','r',function(err,fd){
var buf = new Buffer(255);
//一个汉字的utf编码为三字节数据
//开始写的位置,读的长度,开始读的位置
fs.read(fd,buf,0,9,null,function(err,bytesRead,buffer){
console.log(buffer.slice(0,bytesRead).toString());
//从文件的当前读取位置继续往下读取
fs.read(fd,buf,0,9,3,function(err,bytesRead,buffer){
console.log(buffer.slice(0,bytesRead).toString())
fs.read(fd,buf,0,9,null,function(err,bytesRead,buffer){
console.log(buffer.slice(0,bytesRead).toString())
})
})
})
})
这段代码进行了三次代码的读取,第一次的position值为null,第二次的position值为3,第三次的position值为null
我们发现,第一次是从头开始读取,第二次是从position指定的开始位置读取,第三次却从第一次读取结束的位置继续进行了读取。
由此可知:
当read函数在读取文件时,如果传入了position值,文件指针是不会发生移动的,而当postion值为null时,文件指针会向后移动读取的字节数。
也就是说,position值的位置是相对的,指针的位置是绝对的。如果你用position读取,那么你的定位是绝对的,文件总是从你指定的position的位置开始读取,不受上一次读取的影响。