当前位置: 首页>>代码示例>>C#>>正文


C# Span.ReadUInt16方法代码示例

本文整理汇总了C#中Span.ReadUInt16方法的典型用法代码示例。如果您正苦于以下问题:C# Span.ReadUInt16方法的具体用法?C# Span.ReadUInt16怎么用?C# Span.ReadUInt16使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Span的用法示例。


在下文中一共展示了Span.ReadUInt16方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: ReadUInt16

        public void ReadUInt16(byte[] bytes, ushort expected)
        {
            var span = new Span<byte>(bytes);
            ushort value = span.ReadUInt16();
            Assert.Equal(expected, value);

            var roSpan = new ReadOnlySpan<byte>(bytes);
            value = span.ReadUInt16();
            Assert.Equal(expected, value);
        }
开发者ID:nguerrera,项目名称:corefxlab,代码行数:10,代码来源:BasicUnitTests.cs

示例2: TryDecodeCodePoint

        public static bool TryDecodeCodePoint(Span<byte> buffer, out UnicodeCodePoint codePoint, out int encodedBytes)
        {
            if (buffer.Length < 2)
            {
                codePoint = default(UnicodeCodePoint);
                encodedBytes = default(int);
                // buffer too small
                return false;
            }

            uint codePointValue = buffer.ReadUInt16();
            encodedBytes = 2;
            if (UnicodeCodePoint.IsSurrogate((UnicodeCodePoint)codePointValue))
            {
                // TODO: Check if compiler optimized it so codePointValue low range is checked only once
                if (!UnicodeCodePoint.IsHighSurrogate((UnicodeCodePoint)codePointValue) || buffer.Length < 4)
                {
                    codePoint = default(UnicodeCodePoint);
                    encodedBytes = default(int);
                    // invalid high surrogate or buffer too small
                    return false;
                }
                unchecked
                {
                    codePointValue -= UnicodeConstants.Utf16HighSurrogateFirstCodePoint;
                    encodedBytes += 2;
                }
                // high surrogate contains 10 first bits of the code point
                codePointValue <<= 10;

                uint lowSurrogate = buffer.ReadUInt32() >> 16;
                if (!UnicodeCodePoint.IsLowSurrogate((UnicodeCodePoint)lowSurrogate))
                {
                    codePoint = default(UnicodeCodePoint);
                    encodedBytes = default(int);
                    // invalid low surrogate character
                    return false;
                }

                unchecked
                {
                    lowSurrogate -= UnicodeConstants.Utf16LowSurrogateFirstCodePoint;
                }
                codePointValue |= lowSurrogate;
            }

            codePoint = (UnicodeCodePoint)codePointValue;

            return true;
        }
开发者ID:antiufo,项目名称:Shaman.ValueString,代码行数:50,代码来源:Utf16LittleEndianEncoder.cs


注:本文中的Span.ReadUInt16方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。