Timer.cs 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Diagnostics;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. namespace bbiwarg.Utility
  8. {
  9. class Timer
  10. {
  11. private static Dictionary<String, Stopwatch> stopwatches = new Dictionary<string, Stopwatch>();
  12. private static Dictionary<String, long> minTimes = new Dictionary<string, long>();
  13. private static Dictionary<String, long> maxTimes = new Dictionary<string, long>();
  14. private static Dictionary<String, long> sumTimes = new Dictionary<string, long>();
  15. private static Dictionary<String, int> numTimes = new Dictionary<string, int>();
  16. public static void start(String name) {
  17. if (!stopwatches.ContainsKey(name))
  18. {
  19. stopwatches.Add(name, new Stopwatch());
  20. minTimes.Add(name, int.MaxValue);
  21. maxTimes.Add(name, 0);
  22. sumTimes.Add(name, 0);
  23. numTimes.Add(name, 0);
  24. }
  25. stopwatches[name].Restart();
  26. }
  27. public static void stop(String name) {
  28. stopwatches[name].Stop();
  29. long time = stopwatches[name].ElapsedMilliseconds;
  30. if (time < minTimes[name]) minTimes[name] = time;
  31. if (time > maxTimes[name]) maxTimes[name] = time;
  32. sumTimes[name] += time;
  33. numTimes[name]++;
  34. }
  35. public static void output(String name) {
  36. Console.WriteLine("name:" + name + "\t" + "mean:" + (sumTimes[name] / Math.Max(numTimes[name],1)) + "\t" + "min:" + minTimes[name] + "\t" + "max:" + maxTimes[name]);
  37. }
  38. public static void outputAll() {
  39. Console.WriteLine("---TIMERS-START---");
  40. foreach (String name in stopwatches.Keys) {
  41. output(name);
  42. }
  43. Console.WriteLine("---TIMERS-END---");
  44. }
  45. }
  46. }