Мне было интересно, есть ли какие-либо последствия для производительности между использованием TPL TaskFactory.FromAsync
и использованием TaskFactory.StartNew
на блокирующих версиях методов.Я пишу TCP-сервер, который будет поддерживать не более 100 одновременных подключений.После написания кода с первой опцией и объединения нескольких операций чтения и записи с продолжением, я остался уродливым, трудным для отладки кода.
Я полагаю, что написание кода с синхронной версией, а затем добавление его в Задачу уменьшит сложность и повысит тестируемость, но я беспокоюсь о влиянии на производительность для этого.
Например,Существуют ли различия в производительности между этими двумя вызовами:
NetworkStream stream;
byte[] data;
int bytesRead;
//using FromAsync
Task<int> readChunk = Task<int>.Factory.FromAsync (
stream.BeginRead, stream.EndRead,
data, bytesRead, data.Length - bytesRead, null);
//using StartNew with blocking version
Task<int> readChunk2 = Task<int>.Factory.StartNew(() =>
stream.Read(data, bytesRead, data.Length - bytesRead));