Jump to content

Выключение петли

Отключение цикла — это оптимизация компилятора . Он перемещает условное выражение внутри цикла за его пределы, дублируя тело цикла и помещая его версию внутри каждого из предложений if и else условного оператора. [1] Это может улучшить распараллеливание цикла. Поскольку современные процессоры могут быстро работать с векторами, это улучшение увеличивает скорость работы программы.

Вот простой пример. Предположим, мы хотим добавить два массива x и y , а также сделать что-то в зависимости от переменной w . У нас есть следующий код C :

  int   i  ,   w  ,   x  [  1000  ],   y  [  1000  ];    для   (  я знак   равно   0  ;   я   <   1000  ;   я  ++  )   {      Икс  [  я  ]   +=   y  [  я  ];      если   (  ш  )        y  [  я  ]   знак равно   0  ;    } 

Условие внутри этого цикла затрудняет безопасное распараллеливание этого цикла. Когда мы отключаем цикл, это становится:

  int   i  ,   w  ,   x  [  1000  ],   y  [  1000  ];    если   (  ш  )   {      для   (  я   знак равно   0  ;   я   <   1000  ;   я  ++  )   {        Икс  [  я  ]   +=   y  [  я  ];        у  [  я  ]   знак равно   0  ;      } }    Еще   {   для      (   я  знак   равно   0  ;   я   <   1000  ;   я  ++  )   {        Икс  [  я  ]   +=   y  [  я  ];      }    } 

Хотя отключение цикла может удвоить объем написанного кода, каждый из этих новых циклов теперь можно оптимизировать отдельно.

Отключение цикла было введено в gcc в версии 3.4. [2]

  1. ^ Купер, Кейт; Торчон, Линда (2004). Разработка компилятора . ISBN  9781558606982 .
  2. ^ «Серия выпусков GCC 3.4 — изменения, новые функции и исправления — проект GNU» .
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: a1220bda81ac9504f01749b752e07131__1673524920
URL1:https://arc.ask3.ru/arc/aa/a1/31/a1220bda81ac9504f01749b752e07131.html
Заголовок, (Title) документа по адресу, URL1:
Loop unswitching - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)