是什么ReadOnlySequence
?我知道为什么以及如何使用Span
and Memory
,但我不知道为什么需要这个序列。一些SequencePosition
,ReadOnlySequenceSegment
。我查看了如何使用它们并看到了类似这样的内容:
ReadOnlySequence<byte> bytes = ...;
// ...
foreach (var _byte in bytes)
{
if (_byte.Span[0] == 0x00)
{
// ...
}
}
问题是,还有什么比这更糟糕的:
ReadOnlySpan<byte> bytes = ...;
// ...
foreach (var _byte in bytes)
{
if (_byte == 0x00)
{
// ...
}
}
Span
/ReadOnlySpan
和Memory
/ReadOnlyMemory
表示顺序(连续)的内存块,对于大多数情况来说这已经足够了(数组、stackalloc、字符串等),但在某些情况下我们需要处理不同的内存区域(几个对象Memory
为一个),然后需要ReadOnlySequence
. 这实际上是一个来自 的链表ReadOnlyMemory
。没有ReadOnly
版本,因为 根据使用模式,.net 工作人员认为写入不同的内存区域是不合逻辑的。在普通/真实代码中,您可能不会像
Span
. 大多数情况下,或者更确切地说,我唯一确定使用它的地方是Pipelines,这是一个在 Streams 之上运行的新 API,以及一个以SequenceReader形式出现的包装器。Pipelines
+ReadOnlySequence
允许您简化阅读代码,程序员无需担心缓冲区的大小,即读取了不完整的消息,即 您需要保存当前缓冲区并读取数据,反之亦然,已读取太多。看一个简单的例子:
代码变得非常简单,但它解决了上述问题。例如,在您第一次读取时,读取了 4096 个字节,在此阶段它将创建
ReadOnlySequence
由一个内存块组成,但进一步沿着代码Process
开始处理这些数据并理解它还不够,然后它使用AnvanceTo
和-y表示reader
我使用了 0 个字节,但只是拍摄了所有 4096 个字节,在循环的下一个阶段,将读取另一个 4096 个字节块(进入单独的缓冲区),并且Process
可能已经有足够的信息。这是简化/好处Pipelines
+出现的地方ReadOnlySequence
,因为。用手,代码会变得更复杂和更慢(更多位置),在文章中Pipelines
你可以比较代码的大小。