using BenchmarkDotNet.Attributes;
using NewLife.Data;
namespace Benchmark.PacketBenchmarks;
/// <summary>ReadOnlyPacket 性能测试</summary>
[MemoryDiagnoser]
[SimpleJob(iterationCount: 20)]
public class ReadOnlyPacketBenchmark
{
private Byte[] _data = null!;
[Params(64, 1024, 8192)]
public Int32 Size { get; set; }
[GlobalSetup]
public void Setup()
{
_data = new Byte[Size];
Random.Shared.NextBytes(_data);
}
[Benchmark(Description = "构造(byte[])")]
public ReadOnlyPacket CreateFromArray() => new(_data);
[Benchmark(Description = "构造(ArraySegment)")]
public ReadOnlyPacket CreateFromSegment() => new(new ArraySegment<Byte>(_data, 0, Size));
[Benchmark(Description = "构造(IPacket拷贝)")]
public ReadOnlyPacket CreateFromPacket()
{
IPacket source = new ArrayPacket(_data);
return new ReadOnlyPacket(source);
}
[Benchmark(Description = "GetSpan")]
public Span<Byte> GetSpan()
{
var pk = new ReadOnlyPacket(_data);
return pk.GetSpan();
}
[Benchmark(Description = "GetMemory")]
public Memory<Byte> GetMemory()
{
var pk = new ReadOnlyPacket(_data);
return pk.GetMemory();
}
[Benchmark(Description = "TryGetArray")]
public Boolean TryGetArray()
{
var pk = new ReadOnlyPacket(_data);
return pk.TryGetArray(out _);
}
[Benchmark(Description = "Slice")]
public IPacket SliceTest()
{
var pk = new ReadOnlyPacket(_data);
return pk.Slice(10, Size / 2);
}
[Benchmark(Description = "Indexer读")]
public Byte IndexerRead()
{
var pk = new ReadOnlyPacket(_data);
return pk[Size / 2];
}
[Benchmark(Description = "ToArray")]
public Byte[] ToArrayTest()
{
var pk = new ReadOnlyPacket(_data);
return pk.ToArray();
}
[Benchmark(Description = "隐式转换byte[]")]
public ReadOnlyPacket ImplicitFromByteArray() => _data;
}
/// <summary>ReadOnlyPacket 多线程性能测试</summary>
[MemoryDiagnoser]
[SimpleJob(iterationCount: 20)]
public class ReadOnlyPacketConcurrencyBenchmark
{
private Byte[] _data = null!;
[Params(1024)]
public Int32 Size { get; set; }
[Params(1, 4, 16, 32)]
public Int32 ThreadCount { get; set; }
[GlobalSetup]
public void Setup()
{
_data = new Byte[Size];
Random.Shared.NextBytes(_data);
}
[Benchmark(Description = "多线程构造")]
public void ConcurrentCreate()
{
Parallel.For(0, ThreadCount, t =>
{
for (var i = 0; i < 1000; i++)
{
_ = new ReadOnlyPacket(_data);
}
});
}
[Benchmark(Description = "多线程GetSpan")]
public void ConcurrentGetSpan()
{
Parallel.For(0, ThreadCount, t =>
{
for (var i = 0; i < 1000; i++)
{
var pk = new ReadOnlyPacket(_data);
_ = pk.GetSpan();
}
});
}
[Benchmark(Description = "多线程Slice")]
public void ConcurrentSlice()
{
Parallel.For(0, ThreadCount, t =>
{
for (var i = 0; i < 1000; i++)
{
var pk = new ReadOnlyPacket(_data);
_ = pk.Slice(10, Size / 2);
}
});
}
}
|