我正在尝试使用.NET Core2.1中的Span<byte>
重载将KeyValuePair<string, string>
编码为UTF-8 key='value'
。
编写GetBytes(ReadOnlySpan<char> chars, Span<byte> bytes)
方法的人显然是Yoda的追随者,因为没有TryGetBytes
替代方法,这很奇怪,因为Utf8Formatter为所有非字符串原始类型提供了TryWrite。
因此,我有两种选择来编写扩展方法来实现这一点。
选项1:
public static bool TryGetBytes(this Encoding encoding, ReadOnlySpan<char> str, Span<byte> bytes, out int written)
{
try
{
written = Encoding.UTF8.GetBytes(str, span);
return true;
}
catch (ArgumentException)
{
written = 0;
return false;
}
选项2:
public static bool TryGetBytes(this Encoding encoding, ReadOnlySpan<char> str, Span<byte> bytes, out int written)
{
if (encoding.GetByteCount(str) > span.Length)
{
written = 0;
return false;
}
written = Encoding.UTF8.GetBytes(str, span);
return true;
}
假设在热路径上“空间不足”的情况会相当频繁地(比如,50次中有1次)命中,那么哪种情况对性能更好?
发布于 2019-02-03 14:24:17
当我写这个问题的时候,我想“为什么不直接用BenchmarkDotNet呢?”所以我就这么做了。
答:GetByteCount
比try/catch
快两个数量级。
结果如下:
BenchmarkDotNet=v0.11.3, OS=Windows 10.0.17763.253 (1809/October2018Update/Redstone5)
Intel Core i7-7700HQ CPU 2.80GHz (Kaby Lake), 1 CPU, 8 logical and 4 physical cores
.NET Core SDK=2.2.102
[Host] : .NET Core 2.2.1 (CoreCLR 4.6.27207.03, CoreFX 4.6.27207.03), 64bit RyuJIT
DefaultJob : .NET Core 2.2.1 (CoreCLR 4.6.27207.03, CoreFX 4.6.27207.03), 64bit RyuJIT
| Method | Mean | Error | StdDev | Gen 0/1k Op | Gen 1/1k Op | Gen 2/1k Op | Allocated Memory/Op |
|--------- |------------:|-----------:|----------:|------------:|------------:|------------:|--------------------:|
| TryCatch | 40,985.9 ns | 800.034 ns | 785.74 ns | 0.4272 | - | - | 1392 B |
| TryCount | 366.5 ns | 8.450 ns | 10.38 ns | - | - | - | - |
https://stackoverflow.com/questions/54503668
复制相似问题