Andy Melnikov (nponeccop) wrote,
Andy Melnikov
nponeccop

Оптимизация проверки на попадание в диапазон

В случае беззнаковых чисел условие value >= min && value <= max заменяется на условие value - min < max - min. Получаем одно ветвление вместо двух.

Еще замечание по поводу ленивости: теоретически это выражение можно вычислить в рамках x86 вообще без ветвлений. С++ же в случае value >= min && value <= get_max() не имеет права вызывать get_max() в случае если первый операнд && ложный. Это приводит не только к положительным последствиям (если функция max() длинная - то экономится время), но и к отрицательным - компилятор не сможет избавиться от ветвления.
Tags: compiler design
Subscribe

  • Post a new comment

    Error

    default userpic

    Your reply will be screened

    Your IP address will be recorded 

    When you submit the form an invisible reCAPTCHA check will be performed.
    You must follow the Privacy Policy and Google Terms of use.
  • 0 comments