Книга: Программирование мобильных устройств на платформе .NET Compact Framework

Листинг 7.1. Пример кода для измерения временных интервалов, который вы можете использовать для хронометража работы своих приложений

Листинг 7.1. Пример кода для измерения временных интервалов, который вы можете использовать для хронометража работы своих приложений

using System;
internal class PerformanceSampling {
 //Значение этого параметра может быть задано произвольным, но количество
 //тестовых интервалов, равное 8, представляется достаточным для
 // большинства случаев
 const int NUMBER_SAMPLERS = 8;
 static string[] m_perfSamplesNames = new string[NUMBER_SAMPLERS];
 static int[] m_perfSamplesStartTicks = new int[NUMBER_SAMPLERS];
 static int[] m_perfSamplesDuration = new int[NUMBER_SAMPLERS];
 //Определить начальное значение счетчика тактов системных часов
 //для интервала
 internal static void StartSample(int sampleIndex, string sampleName) {
  m_perfSamplesNames[sampleIndex] = sampleName;
  m_perfSamplesStartTicks[sampleIndex] = System.Environment.TickCount;
 }
 //Определить конечное значение счетчика тактов системных часов
 //для интервала
 internal static void StopSample(int sampleIndex) {
  int stopTickCount = System.Environment.TickCount;
  //Счетчик тактов системных часов сбрасывается в ноль каждые 24,9 дня
  //(что соответствует примерно 2 миллиардам миллисекунд).
  //Эта маловероятная возможность будет принята нами во внимание
  if (stopTickCount >=m_perfSamplesStartTicks[sampleIndex]) {
   //Обычно будет выполняться этот код
   m_perfSamplesDuration[sampleIndex] = stopTickCount - m_perfSamplesStartTicks[sampleIndex];
  } else {
   //Значение счетчика тактов "перешло" через ноль,
   //и мы должны это учесть
   m_perfSamplesDuration[sampleIndex] = stopTickCount + (int.MaxValue - m_perfSamplesStartTicks[sampleIndex]) + 1;
  }
 }
 //Возвратить длительность тестового интервала
 //(в миллисекундах)
 internal static int GetSampleDuration(int sampleIndex) {
  return m_perfSamplesDuration[sampleIndex];
 }
 //Возвращает длительность истекшего тестового
 //интервала в секундах
 internal static string GetSampleDurationText(int sampleIndex) {
  return m_perfSamplesNames[sampleIndex] + ": " +
   System.Convert.ToString((m_perfSamplesDuration[sampleIndex] /(double) 1000.0)) +
   " секунд.";
 }
}

Оглавление книги


Генерация: 1.618. Запросов К БД/Cache: 3 / 1
поделиться
Вверх Вниз