Сегодня мой босс спросил меня, что будет больше повредить производительность между этими двумя подходами: < /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>
Результат показывает, что подход задачи лучше, но мне интересно, правда ли это. Итак, как правильный путь, когда работаете с такими таймами? Тяжелая работа должна быть остановлена. Поэтому я ответил ему с двумя подходами: оберните тяжелую работу одной задачей и сделайте новую задержку задачи до тайм -аута и ждать обеих задач, или потому что тяжелая задача просто повторяет контекст, чтобы знать, что делать дальше, затем повторите, Поэтому я говорю ему, что мы могли бы потратить время на начало до петли и проверить, начинаются ли различия между сейчас и временем больше, чем время, если он остановит петлю. Затем он спросил меня, подходит ли 2 задачи, замедлит ситуацию или нет. Поэтому я попросил Chatgpt ответить и получил тестовый код. Теперь я знаю, что проверяю это неправильно, и я надеюсь, что могу знать, как мне знать, что мне делать в этом случае.
Подробнее здесь: https://stackoverflow.com/questions/794 ... dealing-wi
Повреждение производительности между подходом задачи и подходом к петле при работе с тайм-аутом ⇐ C#
Место общения программистов C#
1739464289
Anonymous
Сегодня мой босс спросил меня, что будет больше повредить производительность между этими двумя подходами: < /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[i] = 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[i] = new Thread(() =>
{
var startTime = DateTime.UtcNow;
int count = 0;
while ((DateTime.UtcNow - startTime).TotalMilliseconds < timeout)
{
count++; // Simulating work
}
});
threads[i].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>
Результат показывает, что подход задачи лучше, но мне интересно, правда ли это. Итак, как правильный путь, когда работаете с такими таймами? Тяжелая работа должна быть остановлена. Поэтому я ответил ему с двумя подходами: оберните тяжелую работу одной задачей и сделайте новую задержку задачи до тайм -аута и ждать обеих задач, или потому что тяжелая задача просто повторяет контекст, чтобы знать, что делать дальше, затем повторите, Поэтому я говорю ему, что мы могли бы потратить время на начало до петли и проверить, начинаются ли различия между сейчас и временем больше, чем время, если он остановит петлю. Затем он спросил меня, подходит ли 2 задачи, замедлит ситуацию или нет. Поэтому я попросил Chatgpt ответить и получил тестовый код. Теперь я знаю, что проверяю это неправильно, и я надеюсь, что могу знать, как мне знать, что мне делать в этом случае.
Подробнее здесь: [url]https://stackoverflow.com/questions/79436040/performance-damage-between-task-approach-and-while-loop-approach-when-dealing-wi[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия