Мелкозернистый таймер для измерения производительности VBScript

Я делаю некоторые измерения производительности в VBScript. Я хочу измерить, насколько быстро работает мой алгоритм

t1 = Now()  
doAlotOfWork ()  
t2 = Now()  
MsgBox "Operation took " & DateDiff ("s", t1, t2)  & " seconds."

Это дает мне время в секундах. Если один алгоритм приводит к времени выполнения 1 секунда, а другой к 2 секундам, это вряд ли даст мне какую-либо полезную информацию. Мне нужно взорвать размер задачи до чего-то, что займет минуту.

Кто-нибудь знает способ выполнения таких измерений в VBScript, но затем более детальный. Например, вводит миллисекунды.

У меня такое ощущение, что в WMI должно быть решение.

2 ответа

Решение

Вы можете использовать функцию таймера VBScript, чтобы получить истекшее время в миллисекундах:

Функция таймера возвращает количество секунд и миллисекунд, начиная с 12:00.

Если вы работаете в HP QuickTest Pro, вам доступны еще два метода:

Таймеры дадут результат (в миллисекундах), который вы можете сохранить в переменной

MercuryTimers("timerName").Start
Wait 2
Msgbox "Time is ticking..."
MercuryTimers("timerName").Stop
Msgbox "Elapsed time is: " & MercuryTimers("timerName").Elapsedtime & " milliseconds"

Время транзакций отображается в результатах / отчете QTP

Services.StartTransaction "transactionName"
Wait 2
Msgbox "Time is ticking..."
Services.EndTransaction "transactionName"
Другие вопросы по тегам