<?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=ProfilerClear</id>
	<title>ProfilerClear - Revision history</title>
	<link rel="self" type="application/atom+xml" href="http://sfsys.ru/index.php?action=history&amp;feed=atom&amp;title=ProfilerClear"/>
	<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=ProfilerClear&amp;action=history"/>
	<updated>2026-04-04T10:22:31Z</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=ProfilerClear&amp;diff=1786&amp;oldid=prev</id>
		<title>Admin: 1 revision imported</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=ProfilerClear&amp;diff=1786&amp;oldid=prev"/>
		<updated>2021-02-07T06:52:25Z</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:52, 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=ProfilerClear&amp;diff=1785&amp;oldid=prev</id>
		<title>Admin at 12:06, 10 June 2019</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=ProfilerClear&amp;diff=1785&amp;oldid=prev"/>
		<updated>2019-06-10T12:06:19Z</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=ProfilerClear&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;
|visual=0}}&lt;br /&gt;
{{HeadLinks|&lt;br /&gt;
* [[Main_Page|Начальная страница]]&lt;br /&gt;
* [[Общее_описание_языка|Общее описание]]&lt;br /&gt;
* [[Объекты]]&lt;br /&gt;
* [[Функции общего назначения]]}}&lt;br /&gt;
Функция очищает данные, накопленные профайлером. См. [[ProfilerStart]], [[Встроенный отладчик]], [[Встроенный профайлер]]. &lt;br /&gt;
&lt;br /&gt;
== Синтаксис ==&lt;br /&gt;
&amp;lt;code&amp;gt;&lt;br /&gt;
'''ProfilerClear'''()&lt;br /&gt;
&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Примеры ==&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
  Function Square(a)&lt;br /&gt;
    Exit a*a;&lt;br /&gt;
  EndFunction&lt;br /&gt;
&lt;br /&gt;
//Включить режим отладки&lt;br /&gt;
DebuggingRights(1);&lt;br /&gt;
&lt;br /&gt;
//Очистить предыдущие результаты профилирования&lt;br /&gt;
ProfilerClear;&lt;br /&gt;
&lt;br /&gt;
//Включить профайлер&lt;br /&gt;
ProfilerStart;&lt;br /&gt;
&lt;br /&gt;
//Находим разницу во времени выполнения функции разными способами&lt;br /&gt;
For i:=1 to 100000 Do&lt;br /&gt;
  Square(i);&lt;br /&gt;
EndDo;&lt;br /&gt;
&lt;br /&gt;
For i:=1 to 100000 Do&lt;br /&gt;
  ExecuteFunction(&amp;quot;Square&amp;quot;,1,i);&lt;br /&gt;
EndDo;&lt;br /&gt;
&lt;br /&gt;
//Останавливаем профайлер&lt;br /&gt;
ProfilerStop;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Период:=dbgHRPCCurrent();&lt;br /&gt;
For i:=1 to 100000 Do&lt;br /&gt;
  Exec(&amp;quot;Square(i)&amp;quot;);&lt;br /&gt;
EndDo;&lt;br /&gt;
Период:=dbgHRPCGetPeriod(Период)/1000000;&lt;br /&gt;
Message(&amp;quot;Выполнение Exec: &amp;quot;+Период+&amp;quot; мс.&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
//Вызываем окно отладчика для просмотра результатов профилирования&lt;br /&gt;
DebugBreak;&lt;br /&gt;
&lt;br /&gt;
//Функция DebugBreak не должна быть последней в модуле&lt;br /&gt;
Message(&amp;quot;Тест выполнен успешно&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
//Для i5 на Windows 7 результаты профилирования были следующими:&lt;br /&gt;
//* Прямой вызов функции занял 223 мс.&lt;br /&gt;
//* Использование функции ExecuteFunction заняло 296 мс.&lt;br /&gt;
//* Компиляция текста и вызов функции заняли 1210 мс. &lt;br /&gt;
//  Комментарий: компиляция и выполнение уменьшает скорость работы профайлера, так как увеличивается количество исходных текстов в массиве, из которого производится поиск при профилировании&lt;br /&gt;
//  Для массива текстов размером в ~10000, профайлер замедляет исполнение примерно в 1.4 раза по сравнению с работой профайлера с пустым массивом (коэффициент можно найти, если переставить местами&lt;br /&gt;
//      циклы, включить цикл Exec в профилирование и сравнить результаты). Поэтому, время исполнения последнего цикла было найдено без помощи профайлера.&lt;br /&gt;
&lt;br /&gt;
//Вывод: компиляция текста осуществляется сравнительно быстро для небольших текстовых фрагментов, но такое исполнение примерно в 5 раз медленнее, чем вызов функции напрямую.&lt;br /&gt;
//  Поэтому для случаев, когда это возможно, выгоднее использовать функцию ExecuteFunction.&lt;br /&gt;
//Время компиляции Exec нивелируется для больших текстов вызываемых небольшое количество раз (обычный способ исполнения скрипта).&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>
		
	</entry>
</feed>