1 / 1 / 0
Регистрация: 07.06.2013
Сообщений: 39
|
|
Как оптимизируются логические операторы?02.09.2013, 06:12. Показов 1783. Ответов 5
Метки нет Все метки)
(
Интуиция подсказывает, что компиляторы могут оптимизировать проверку условий. Например:
if(A && B)... В случае, если A==false, то нет смысла тратить процессорное время на проверку второго условия. Тогда можно избежать лишних IF, например при проверке границ массива. if((A>=0)&&(array[A]==5))... В этом случае хотелось бы видеть оптимизацию. Без нее будет ошибка при попытке обратиться за границы массива. С другой стороны, эта оптимизация может наоборот вызвать сбой логики. if((A)&&(B++ > 0) )... Здесь нужно, чтоб "B" во время проверки увеличилась на 1. Чего не произойдет, если действует оптимизация. И вопрос. Как эти случаи регламентированы в стандартах С++ и как компиляторы поступают? И в случае оптимизации могут ли компиляторы проверять логические условия не в том порядке, как ты их написал, а проверяя вначале наименее простые условия?
0
|
02.09.2013, 06:12 | |
Ответы с готовыми решениями:
5
Операторы отношений и логические операторы |
Почетный модератор
![]() ![]() 5851 / 2862 / 392
Регистрация: 01.11.2011
Сообщений: 6,906
|
|
02.09.2013, 09:40 | |
Pro_ha, может будет интересно: ленивые вычисления.
0
|
02.09.2013, 09:40 | ||||||
Помогаю со студенческими работами здесь
6
Логические операторы
Логические операторы в выражениях Не работают логические операторы Искать еще темы с ответами Или воспользуйтесь поиском по форуму:
|
|
Новые блоги и статьи
![]() |
||||
Не удержался от оценки концепции двигателя Стирлинга.
Hrethgir 03.04.2025
Сколько не пытался - она выдавала правильные схемы, причём случайно рисовала горячие области в середине, холодные по краям, трубки с краёв в низ и магнит в соединяющей, но при этой выдавала описание. . .
|
Метод с двумя буферами (или double buffering) или ping-pong buffering
Hrethgir 02.04.2025
Из ответов LM модели.
Метод, который предполагает использование двух массивов для хранения промежуточных результатов сложения векторов, обычно применяется в сценариях, где необходимо минимизировать. . .
|
На любовном киберфронте
Alexander-7 01.04.2025
Недавно на одном малоизвестном сайте знакомств мною заинтересовалась девушка:
«Текст немного странный. Но, судя по адресу почты, иностранка», – подумал я. Поколебавшись пару суток, я ответил ей:. . .
|
Как работает Node.js изнутри
run.dev 29.03.2025
Node. js изменил подход к разработке веб-приложений, позволив использовать JavaScript не только на стороне клиента, но и на сервере. Созданный в 2009 году Райаном Далем, этот открытый,. . .
|
Моки в Python: Mock Object Library
py-thonny 29.03.2025
Тестирование кода требует особого подхода, когда речь идёт о компонентах, взаимодействующих с внешним миром. Мы часто сталкиваемся с непредсказуемостью HTTP-запросов, чтением данных из базы или. . .
|
JavaScript: Управление памятью и улучшение производительности
run.dev 29.03.2025
В отличие от низкоуровневых языков программирования, JavaScript не требует ручного выделения и освобождения памяти. Здесь работает автоматический сборщик мусора, который определяет, какие объекты. . .
|
Мультитенантная архитектура со SpringBoot и PostgreSQL
ArchitectMsa 29.03.2025
SaaS-приложения редко обслуживают одного клиента и обычно они должны поддерживать множество организаций, каждая из которых работает в своём изолированном пространстве. Мультитенантная архитектура. . .
|
std::span в C++: Производительность и лучшие практики
NullReferenced 28.03.2025
std::span — одно из самых недооценённых нововведений стандарта C++20, которое радикально меняет подход к работе с непрерывными последовательностями данных. По сути, это невладеющее представление. . .
|
Многопоточность в C#: Threadpool
UnmanagedCoder 28.03.2025
Пул потоков в C# — это коллекция заранее созданных и готовых к использованию потоков, которые находятся в распоряжении приложения. Вместо того чтобы создавать и уничтожать потоки для каждой небольшой. . .
|
Вопросы на собеседованиях по микросервисам
ArchitectMsa 27.03.2025
Работодатели ищут не просто разработчиков, знающих базовые концепции, а специалистов, разбирающихся в тонкостях масштабирования, отказоустойчивости и производительности. Сейчас на первый план выходят. . .
|