CounterSample.cs 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. //
  2. // System.Diagnostics.CounterSample.cs
  3. //
  4. // Authors:
  5. // Jonathan Pryor ([email protected])
  6. // Andreas Nahr ([email protected])
  7. //
  8. // (C) 2002
  9. // (C) 2003 Andreas Nahr
  10. //
  11. //
  12. // Permission is hereby granted, free of charge, to any person obtaining
  13. // a copy of this software and associated documentation files (the
  14. // "Software"), to deal in the Software without restriction, including
  15. // without limitation the rights to use, copy, modify, merge, publish,
  16. // distribute, sublicense, and/or sell copies of the Software, and to
  17. // permit persons to whom the Software is furnished to do so, subject to
  18. // the following conditions:
  19. //
  20. // The above copyright notice and this permission notice shall be
  21. // included in all copies or substantial portions of the Software.
  22. //
  23. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  24. // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  25. // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  26. // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
  27. // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
  28. // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
  29. // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  30. //
  31. namespace System.Diagnostics {
  32. public struct CounterSample {
  33. private long rawValue;
  34. private long baseValue;
  35. private long counterFrequency;
  36. private long systemFrequency;
  37. private long timeStamp;
  38. private long timeStamp100nSec;
  39. private long counterTimeStamp;
  40. private PerformanceCounterType counterType;
  41. public CounterSample (long rawValue,
  42. long baseValue,
  43. long counterFrequency,
  44. long systemFrequency,
  45. long timeStamp,
  46. long timeStamp100nSec,
  47. PerformanceCounterType counterType)
  48. : this (rawValue, baseValue, counterFrequency,
  49. systemFrequency, timeStamp, timeStamp100nSec,
  50. counterType, 0)
  51. {
  52. }
  53. public CounterSample (long rawValue,
  54. long baseValue,
  55. long counterFrequency,
  56. long systemFrequency,
  57. long timeStamp,
  58. long timeStamp100nSec,
  59. PerformanceCounterType counterType,
  60. long counterTimeStamp)
  61. {
  62. this.rawValue = rawValue;
  63. this.baseValue = baseValue;
  64. this.counterFrequency = counterFrequency;
  65. this.systemFrequency = systemFrequency;
  66. this.timeStamp = timeStamp;
  67. this.timeStamp100nSec = timeStamp100nSec;
  68. this.counterType = counterType;
  69. this.counterTimeStamp = counterTimeStamp;
  70. }
  71. public static CounterSample Empty = new CounterSample (
  72. 0, 0, 0, 0, 0, 0,
  73. PerformanceCounterType.NumberOfItems32,
  74. 0);
  75. public long BaseValue {
  76. get {return baseValue;}
  77. }
  78. public long CounterFrequency {
  79. get {return counterFrequency;}
  80. }
  81. public long CounterTimeStamp {
  82. get {return counterTimeStamp;}
  83. }
  84. public PerformanceCounterType CounterType {
  85. get {return counterType;}
  86. }
  87. public long RawValue {
  88. get {return rawValue;}
  89. }
  90. public long SystemFrequency {
  91. get {return systemFrequency;}
  92. }
  93. public long TimeStamp {
  94. get {return timeStamp;}
  95. }
  96. public long TimeStamp100nSec {
  97. get {return timeStamp100nSec;}
  98. }
  99. public static float Calculate (CounterSample counterSample)
  100. {
  101. return CounterSampleCalculator.ComputeCounterValue (counterSample);
  102. }
  103. public static float Calculate (CounterSample counterSample,
  104. CounterSample nextCounterSample)
  105. {
  106. return CounterSampleCalculator.ComputeCounterValue (counterSample, nextCounterSample);
  107. }
  108. }
  109. }