Сегодня мой босс спросил меня, что будет больше повредить производительность между этими двумя подходами: < /p>
var delayTask = Task.Delay(timeout);
var doSomethingTask = Task.Run( async ()=> { //do something here });
await Task.WhenAny(delayTask, doSomethingTask)
< /code>
и < /p>
while (GetDifferenceBetweenTimestamp(timestart, now) > timeout) { //do something here }
< /code>
Мой ответ был, что подход задания будет лучше, но он сказал, что он будет дважды работать над процессором. Поэтому я спрашиваю CHATGPT тестового кода, как это: < /p>
using System;
using System.Diagnostics;
using System.Threading;
using System.Threading.Tasks;
class PerformanceTest
{
static async Task TaskBasedMethod(int timeout, int instances)
{
var stopwatch = Stopwatch.StartNew();
Task[] tasks = new Task[instances];
for (int i = 0; i < instances; i++)
{
tasks = Task.Run(async () =>
{
var delayTask = Task.Delay(timeout);
var doSomethingTask = Task.Run(() =>
{
int count = 0;
while (count < 1000000) count++; // Simulating work
});
await Task.WhenAny(delayTask, doSomethingTask);
});
}
await Task.WhenAll(tasks);
stopwatch.Stop();
Console.WriteLine($"Task-Based Method - Total Time: {stopwatch.ElapsedMilliseconds} ms");
}
static void LoopBasedMethod(int timeout, int instances)
{
var stopwatch = Stopwatch.StartNew();
Thread[] threads = new Thread[instances];
for (int i = 0; i < instances; i++)
{
threads = new Thread(() =>
{
var startTime = DateTime.UtcNow;
int count = 0;
while ((DateTime.UtcNow - startTime).TotalMilliseconds < timeout)
{
count++; // Simulating work
}
});
threads.Start();
}
foreach (var thread in threads)
{
thread.Join(); // Wait for all to finish
}
stopwatch.Stop();
Console.WriteLine($"Loop-Based Method - Total Time: {stopwatch.ElapsedMilliseconds} ms");
}
static void MeasureResourceUsage()
{
var process = Process.GetCurrentProcess();
Console.WriteLine($"CPU Time: {process.TotalProcessorTime.TotalMilliseconds} ms");
Console.WriteLine($"Memory Usage: {process.WorkingSet64 / 1024 / 1024} MB");
}
static async Task Main()
{
int timeout = 100; // 100ms
int instances = 500; // 1M instances
Console.WriteLine("Testing Task-Based Method...");
await TaskBasedMethod(timeout, instances);
MeasureResourceUsage();
Console.WriteLine("Testing Loop-Based Method...");
LoopBasedMethod(timeout, instances);
MeasureResourceUsage();
}
}
< /code>
Результат показывает, что подход задачи лучше, но мне интересно, правда ли это. Так что же подходит при работе с таковым тайм -аутом?
Подробнее здесь: https://stackoverflow.com/questions/794 ... dealing-wi
Повреждение производительности между подходом задачи и подходом к петле при работе с тайм-аутом ⇐ C#
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение