<?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=%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80_%D1%81%D1%80%D0%B0%D0%B2%D0%BD%D0%B5%D0%BD%D0%B8%D1%8F_%D1%84%D1%83%D0%BD%D0%BA%D1%86%D0%B8%D0%B9_%D1%81%D1%82%D1%80%D0%BE%D0%BA-%D0%BC%D0%B0%D1%81%D1%81%D0%B8%D0%B2%D0%BE%D0%B2_%D0%B8_%D1%82%D0%B0%D0%B1%D0%BB%D0%B8%D1%86</id>
	<title>Пример сравнения функций строк-массивов и таблиц - Revision history</title>
	<link rel="self" type="application/atom+xml" href="http://sfsys.ru/index.php?action=history&amp;feed=atom&amp;title=%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80_%D1%81%D1%80%D0%B0%D0%B2%D0%BD%D0%B5%D0%BD%D0%B8%D1%8F_%D1%84%D1%83%D0%BD%D0%BA%D1%86%D0%B8%D0%B9_%D1%81%D1%82%D1%80%D0%BE%D0%BA-%D0%BC%D0%B0%D1%81%D1%81%D0%B8%D0%B2%D0%BE%D0%B2_%D0%B8_%D1%82%D0%B0%D0%B1%D0%BB%D0%B8%D1%86"/>
	<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80_%D1%81%D1%80%D0%B0%D0%B2%D0%BD%D0%B5%D0%BD%D0%B8%D1%8F_%D1%84%D1%83%D0%BD%D0%BA%D1%86%D0%B8%D0%B9_%D1%81%D1%82%D1%80%D0%BE%D0%BA-%D0%BC%D0%B0%D1%81%D1%81%D0%B8%D0%B2%D0%BE%D0%B2_%D0%B8_%D1%82%D0%B0%D0%B1%D0%BB%D0%B8%D1%86&amp;action=history"/>
	<updated>2026-04-04T14:02:20Z</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=%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80_%D1%81%D1%80%D0%B0%D0%B2%D0%BD%D0%B5%D0%BD%D0%B8%D1%8F_%D1%84%D1%83%D0%BD%D0%BA%D1%86%D0%B8%D0%B9_%D1%81%D1%82%D1%80%D0%BE%D0%BA-%D0%BC%D0%B0%D1%81%D1%81%D0%B8%D0%B2%D0%BE%D0%B2_%D0%B8_%D1%82%D0%B0%D0%B1%D0%BB%D0%B8%D1%86&amp;diff=3184&amp;oldid=prev</id>
		<title>Admin: 1 revision imported</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80_%D1%81%D1%80%D0%B0%D0%B2%D0%BD%D0%B5%D0%BD%D0%B8%D1%8F_%D1%84%D1%83%D0%BD%D0%BA%D1%86%D0%B8%D0%B9_%D1%81%D1%82%D1%80%D0%BE%D0%BA-%D0%BC%D0%B0%D1%81%D1%81%D0%B8%D0%B2%D0%BE%D0%B2_%D0%B8_%D1%82%D0%B0%D0%B1%D0%BB%D0%B8%D1%86&amp;diff=3184&amp;oldid=prev"/>
		<updated>2021-02-07T06:55:29Z</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:55, 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=%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80_%D1%81%D1%80%D0%B0%D0%B2%D0%BD%D0%B5%D0%BD%D0%B8%D1%8F_%D1%84%D1%83%D0%BD%D0%BA%D1%86%D0%B8%D0%B9_%D1%81%D1%82%D1%80%D0%BE%D0%BA-%D0%BC%D0%B0%D1%81%D1%81%D0%B8%D0%B2%D0%BE%D0%B2_%D0%B8_%D1%82%D0%B0%D0%B1%D0%BB%D0%B8%D1%86&amp;diff=3183&amp;oldid=prev</id>
		<title>Admin at 07:18, 6 November 2020</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80_%D1%81%D1%80%D0%B0%D0%B2%D0%BD%D0%B5%D0%BD%D0%B8%D1%8F_%D1%84%D1%83%D0%BD%D0%BA%D1%86%D0%B8%D0%B9_%D1%81%D1%82%D1%80%D0%BE%D0%BA-%D0%BC%D0%B0%D1%81%D1%81%D0%B8%D0%B2%D0%BE%D0%B2_%D0%B8_%D1%82%D0%B0%D0%B1%D0%BB%D0%B8%D1%86&amp;diff=3183&amp;oldid=prev"/>
		<updated>2020-11-06T07:18:23Z</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;Пример разницы в скорости и сложности программирования для конъюнкции двух текстовых массивов. Данный пример выполнялся для процессора i5.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
Randomize(1);&lt;br /&gt;
&lt;br /&gt;
//Подготовка:&lt;br /&gt;
//Создание и заполнение двух строк с префиксами, разделенной строками _NEWLINE&lt;br /&gt;
//Строки будут иметь формат: &amp;lt;Префикс-индекс&amp;gt; Chr(1) &amp;lt;Случайная строка&amp;gt;&lt;br /&gt;
//Также заполнение двух таблиц такими же значениями&lt;br /&gt;
&lt;br /&gt;
aTab:=Tab.Create(&amp;quot;Индекс,Значение,ФлНайден&amp;quot;);&lt;br /&gt;
aTab2:=Tab.Create(&amp;quot;Индекс,Значение&amp;quot;);&lt;br /&gt;
аСтр:=&amp;quot;&amp;quot;;&lt;br /&gt;
аСтр2:=&amp;quot;&amp;quot;;&lt;br /&gt;
&lt;br /&gt;
//Вариант 1: количество элементов: 10000, длина одного элемента: 5, количество одинаковых элементов (длина результата): 928&lt;br /&gt;
//Вариант 2: количество элементов: 100000, длина одного элемента: 7, количество одинаковых элементов (длина результата): 1043&lt;br /&gt;
&lt;br /&gt;
For i:=1 To 10000 Do //Изменить для варианта 2: 100000&lt;br /&gt;
  бСтр:=Str(Random(10))+Random(10)+Random(10)+Random(10)+Random(10);//Добавить для варианта 2: &amp;quot;+Random(10)+Random(10)&amp;quot;&lt;br /&gt;
  бСтр2:=Str(Random(10))+Random(10)+Random(10)+Random(10)+Random(10);//Добавить для варианта 2: &amp;quot;+Random(10)+Random(10)&amp;quot;&lt;br /&gt;
  AppendStringToBufferedString(аСтр,Str(i)+Chr(1)+бСтр+_NEWLINE);&lt;br /&gt;
  AppendStringToBufferedString(аСтр2,Str(i)+Chr(1)+бСтр2+_NEWLINE);&lt;br /&gt;
  aTab.AddLine(&amp;quot;Индекс,Значение,ФлНайден&amp;quot;,i,бСтр,0);&lt;br /&gt;
  aTab2.AddLine(&amp;quot;Индекс,Значение&amp;quot;,i,бСтр2);&lt;br /&gt;
EndDo;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
ProfilerClear();&lt;br /&gt;
ProfilerStart();&lt;br /&gt;
&lt;br /&gt;
JoinStringValues(аСтр,аСтр2,_NEWLINE,&amp;quot;AND&amp;quot;,Chr(1));&lt;br /&gt;
//Функция выполнялась:&lt;br /&gt;
//Вариант 1: 245 мс.&lt;br /&gt;
//Вариант 2: 22.9 с.&lt;br /&gt;
&lt;br /&gt;
aTab.Sort(&amp;quot;Значение&amp;quot;);&lt;br /&gt;
aTab2.Sort(&amp;quot;Значение&amp;quot;);&lt;br /&gt;
aTab2.Select();&lt;br /&gt;
While aTab2.Next() Do&lt;br /&gt;
  If aTab.FindAndGoto(aTab2.Значение,,&amp;quot;Значение&amp;quot;,1) Then&lt;br /&gt;
    aTab.ФлНайден:=1;&lt;br /&gt;
  EndIf;&lt;br /&gt;
EndDo;&lt;br /&gt;
aTab.CurLine:=0;&lt;br /&gt;
aTab.RemoveLocated(&amp;quot;ФлНайден&amp;quot;,0);&lt;br /&gt;
//Конструкция была выполнена за:&lt;br /&gt;
//Вариант 1: 148 мс.&lt;br /&gt;
//Вариант 2: 6.9 с.&lt;br /&gt;
&lt;br /&gt;
ProfilerStop();&lt;br /&gt;
DebugBreak;&lt;br /&gt;
Message(&amp;quot;Done!&amp;quot;);&lt;br /&gt;
//Таким образом в первом случае скорость выполнения строк-массивов меньше на 65.5%, &lt;br /&gt;
//  во втором случае, когда массив стал в 10 раз больше и количество совпадающих элементов уменьшилось, скорость выполнения строк-массивов стала меньше в 3.32 раза.&lt;br /&gt;
//Вывод: для очень больших массивов рекомендуется пользоваться стандартными методами, даже если начальные данные получены в виде строки с разделителями.&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>
		
	</entry>
</feed>