当前位置: 首页 > 文档资料 > CatLib 中文文档 >

分片流

优质
小牛编辑
115浏览
2023-12-01

分片流可以用于包装指定分片的流。

使指定分片的流访问起来就像传统流那样从开头到结尾。

构建分片流

var segmentStream = new SegmentStream(baseStream, 1024);

分片流的起始位置为基础流的position,在构建分片流时会被记录。

函数原型
SegmentStream(Stream stream, long partSize = 0);
参数描述
stream基础流
partSize分片大小

Length

获取分片流的长度。

var length = segmentStream.Length;
函数原型
long Length { get; }

Position

获取分片流的偏移量

var position = segmentStream.Position;
函数原型
long Position { get; }

Seek

偏移游标到指定位置。

segmentStream.Seek(0, SeekOrigin.Begin);
函数原型
long Seek(long offset, SeekOrigin origin);
参数描述
offset指定的偏移位置
origin偏移方向

Read

读取分片流中的数据,返回值为实际读取的长度。

var read = segmentStream.Read(buffer, 0, buffer.Length);
函数原型
int Read(byte[] buffer, int offset, int count)
参数描述
buffer读取的缓冲区
offset读取缓冲区起始偏移量
count期望读取的长度

Write

分片流不支持写入,会引发一个NotSupportedException异常。

SetLength

分片流不支持设定长度,会引发一个NotSupportedException异常。