<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>http://sfsys.ru/index.php?action=history&amp;feed=atom&amp;title=DbgHRPCGetPeriod</id>
	<title>DbgHRPCGetPeriod - Revision history</title>
	<link rel="self" type="application/atom+xml" href="http://sfsys.ru/index.php?action=history&amp;feed=atom&amp;title=DbgHRPCGetPeriod"/>
	<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=DbgHRPCGetPeriod&amp;action=history"/>
	<updated>2026-04-04T15:43:23Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.31.1</generator>
	<entry>
		<id>http://sfsys.ru/index.php?title=DbgHRPCGetPeriod&amp;diff=626&amp;oldid=prev</id>
		<title>Admin: 1 revision imported</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=DbgHRPCGetPeriod&amp;diff=626&amp;oldid=prev"/>
		<updated>2021-02-07T06:50:37Z</updated>

		<summary type="html">&lt;p&gt;1 revision imported&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revision as of 06:50, 7 February 2021&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-notice&quot; lang=&quot;en&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(No difference)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>
		
	</entry>
	<entry>
		<id>http://sfsys.ru/index.php?title=DbgHRPCGetPeriod&amp;diff=625&amp;oldid=prev</id>
		<title>Admin at 21:52, 24 August 2020</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=DbgHRPCGetPeriod&amp;diff=625&amp;oldid=prev"/>
		<updated>2020-08-24T21:52:04Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;{{infobox function&lt;br /&gt;
|name=DbgHRPCGetPeriod&lt;br /&gt;
|object=[[Функции общего назначения]]&lt;br /&gt;
|caption=Функции отладки&lt;br /&gt;
|type=1&lt;br /&gt;
|status=2&lt;br /&gt;
|db=0&lt;br /&gt;
|exception=Невозможно превратить в число&lt;br /&gt;
|visual=0}}&lt;br /&gt;
{{HeadLinks|&lt;br /&gt;
* [[Main_Page|Начальная страница]]&lt;br /&gt;
* [[Общее_описание_языка|Общее описание]]&lt;br /&gt;
* [[Объекты]]&lt;br /&gt;
* [[Функции общего назначения]]}}&lt;br /&gt;
Отладочная функция получает промежуток времени, прошедший от предыдущего значения таймера высокой точности (High-Resolution Performance Counter, обычно включение происходит в BIOS компьютера) до текущего момента, выраженное в наносекундах. Если таймер не включен на системном уровне, функция возвращает пустое значение. Перевод периода в секунды можно осуществить по формуле &amp;lt;code&amp;gt;&amp;lt;Результат&amp;gt;/1000000000&amp;lt;/code&amp;gt;. Таймер высокой точности позволяет точно замерить время выполнения операций, также он используется встроенным в отладчик профайлером, без него профайлер будет подсчитывать только количество вызовов, но не время их исполнения.&lt;br /&gt;
&lt;br /&gt;
== Синтаксис ==&lt;br /&gt;
&amp;lt;code&amp;gt;&lt;br /&gt;
'''dbgHRPCGetPeriod'''(''&amp;lt;Предыдущее значение т.в.т. (INT)&amp;gt;''):''&amp;lt;Прошедшее время в наносекундах (INT)&amp;gt;''&lt;br /&gt;
&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==== Аргументы ====&lt;br /&gt;
* &amp;lt;code&amp;gt;''&amp;lt;Предыдущее значение т.в.т. (INT)&amp;gt;''&amp;lt;/code&amp;gt; - Числовое значение, предыдущее показание т.в.т.&lt;br /&gt;
&lt;br /&gt;
==== Возвращаемое значение ====&lt;br /&gt;
Функция возвращает число, разницу между предыдущим и текущим показаниями т.в.т., выраженную в наносекундах.&lt;br /&gt;
&lt;br /&gt;
== Примеры ==&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
//Создаем переменную заранее&lt;br /&gt;
a:=0;&lt;br /&gt;
&lt;br /&gt;
Чл1:=Date();&lt;br /&gt;
&lt;br /&gt;
For i:=1 To 1000000 Do&lt;br /&gt;
  a:=0;&lt;br /&gt;
EndDo;&lt;br /&gt;
&lt;br /&gt;
Чл1:=GetPeriodMs(Чл1);&lt;br /&gt;
Message(&amp;quot;Руководствуясь системными часами, миллион операций присваивания занял: &amp;quot;+Чл1+&amp;quot; мс.&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
If DbgHRPCAvailable Then&lt;br /&gt;
  Чл2:=dbgHRPCCurrent();  &lt;br /&gt;
&lt;br /&gt;
  For i:=1 To 1000000 Do&lt;br /&gt;
    a:=0;&lt;br /&gt;
  EndDo;&lt;br /&gt;
&lt;br /&gt;
  Чл2:=dbgHRPCGetPeriod(Чл2);&lt;br /&gt;
  Чл2:=Чл2/1000000;&lt;br /&gt;
  Message(&amp;quot;Руководствуясь т.в.т., миллион операций присваивания занял: &amp;quot;+Чл2+&amp;quot; мс.&amp;quot;);&lt;br /&gt;
EndIf;&lt;br /&gt;
&lt;br /&gt;
//Для i5:&lt;br /&gt;
//&amp;quot;Руководствуясь системными часами, миллион операций присваивания занял: 593 мс.&amp;quot; -- точность этого таймера составляет не более 20мс.&lt;br /&gt;
//&amp;quot;Руководствуясь т.в.т., миллион операций присваивания занял: 597.547944 мс.&amp;quot; -- точность этого таймера очень велика (зависит от конкретной машины)&lt;br /&gt;
//  Если исполнить блок несколько раз, появится разброс в показаниях, обусловленный тем, что операционная система в фоне может выполнять другие процессы.&lt;br /&gt;
//Нужно заметить, что эксперимент не совсем верно ответил на вопрос, какое время занимает выполнение миллиона операций присваивания, так как&lt;br /&gt;
//  и для первого и для второго случая, в это время включаются дополнительные команды конструкции цикла и нахождения времени после окончания цикла.&lt;br /&gt;
//Чтобы исключить время исполнения инструкций цикла и других инструкций, достаточно провести замер без инструкции &amp;quot;a:=0&amp;quot;. Для двух циклов,&lt;br /&gt;
//  время должно быть несколько разным, так как GetPeriodMs и dbgHRPCGetPeriod занимают разное время.&lt;br /&gt;
//&lt;br /&gt;
//Также можно использовать встроенный профайлер, однако, при включенном профайлере скорость исполнения инструкций будет несколько ниже.&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>
		
	</entry>
</feed>