Время многопоточного выполнения функции - C#

Узнай цену своей работы

Формулировка задачи:

Этот код исполняется за 0.4 сек на моём компьюетере
Листинг программы
  1. private void Foo()
  2. {
  3. for (int i = 0; i < 100000000; i++) { }
  4. }
Я вызываю 10 раз foo в потоке и надеюсь, они выполнятся за время соизмеримым со временем выполнения Foo breakpoint1
Листинг программы
  1. new Thread(() => { Foo(); }).Start();
  2. new Thread(() => { Foo(); }).Start();
  3. new Thread(() => { Foo(); }).Start();
  4. new Thread(() => { Foo(); }).Start();
  5. new Thread(() => { Foo(); }).Start();
  6. new Thread(() => { Foo(); }).Start();
  7. new Thread(() => { Foo(); }).Start();
  8. new Thread(() => { Foo(); }).Start();
  9. new Thread(() => { Foo(); }).Start();
  10. new Thread(() => { Foo(); }).Start();
breakpoint2 Однако время выполнения строк между breakpoint1 и breakpoint2 = около 2 сек. это для меня долго, нужно около 0.5 сек. Мои предположения: что кроме этих потоков планировщик обрабатывает и другие. Поправьте если я неправ и помогите добиться нужной скорости.

Решение задачи: «Время многопоточного выполнения функции»

textual
Листинг программы
  1. var stat = new Dictionary<System.Diagnostics.ThreadState, int>();
  2. foreach (System.Diagnostics.ThreadState state in Enum.GetValues(typeof(System.Diagnostics.ThreadState)))
  3. {
  4.     stat.Add(state, 0);
  5. }
  6. foreach (var proc in Process.GetProcesses())
  7. {
  8.     foreach (var grp in proc.Threads
  9.         .Cast<ProcessThread>()
  10.         .Select(t => t.ThreadState)
  11.         .GroupBy(state => state))
  12.     {
  13.         stat[grp.Key] += grp.Count();
  14.     }
  15. }
  16. //stat.Dump();

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

11   голосов , оценка 3.818 из 5

Нужна аналогичная работа?

Оформи быстрый заказ и узнай стоимость

Бесплатно
Оформите заказ и авторы начнут откликаться уже через 10 минут
Похожие ответы