解决MySql布尔型新旧版本兼容问题,采用枚举来表示布尔型的数据表。由正向工程赋值
大石头 authored at 2018-05-15 21:21:05
3.32 KiB
X
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);
            }
        });
    }
}