1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
|
//------------------------------------------------------------
// Copyright (c) Microsoft Corporation. All rights reserved.
//------------------------------------------------------------
namespace System.ServiceModel.Channels
{
using System.Runtime;
class ConnectionBufferPool : QueuedObjectPool<byte[]>
{
const int SingleBatchSize = 128 * 1024;
const int MaxBatchCount = 16;
const int MaxFreeCountFactor = 4;
int bufferSize;
public ConnectionBufferPool(int bufferSize)
{
int batchCount = ComputeBatchCount(bufferSize);
this.Initialize(bufferSize, batchCount, batchCount * MaxFreeCountFactor);
}
public ConnectionBufferPool(int bufferSize, int maxFreeCount)
{
this.Initialize(bufferSize, ComputeBatchCount(bufferSize), maxFreeCount);
}
void Initialize(int bufferSize, int batchCount, int maxFreeCount)
{
Fx.Assert(bufferSize >= 0, "bufferSize must be non-negative");
Fx.Assert(batchCount > 0, "batchCount must be positive");
Fx.Assert(maxFreeCount >= 0, "maxFreeCount must be non-negative");
this.bufferSize = bufferSize;
if (maxFreeCount < batchCount)
{
maxFreeCount = batchCount;
}
base.Initialize(batchCount, maxFreeCount);
}
public int BufferSize
{
get
{
return this.bufferSize;
}
}
protected override byte[] Create()
{
return DiagnosticUtility.Utility.AllocateByteArray(this.bufferSize);
}
static int ComputeBatchCount(int bufferSize)
{
int batchCount;
if (bufferSize != 0)
{
batchCount = (SingleBatchSize + bufferSize - 1) / bufferSize;
if (batchCount > MaxBatchCount)
{
batchCount = MaxBatchCount;
}
}
else
{
// It's OK to have zero bufferSize
batchCount = MaxBatchCount;
}
return batchCount;
}
}
}
|