|
52 / 37 / 9
Регистрация: 13.06.2019
Сообщений: 209
|
||||||
Какая альтернатива switch быстрее?15.05.2020, 20:02. Показов 3050. Ответов 3
Метки нет (Все метки)
что если требуется множественное ветвление алгоритма
причём имеется индекс ветви наподобие индекса массива тогда конструкции типа switch оказываются не самыми эффективными given-when, if-elsif начинают тормозить с ростом числа вариантов обращение к элементу массива по индексу происходит без сравнений, при помощи вычисления позиции. с ростом числа вариантов выбор в массиве становится быстрее чем условный переход. пример в подтверждение идеи
вот собственно хотел поделиться находкой.
0
|
||||||
| 15.05.2020, 20:02 | |
|
Ответы с готовыми решениями:
3
Mutator как альтернатива switch: оправдано ли
|
|
Невнимательный
|
|||||||||||
| 17.05.2020, 02:39 | |||||||||||
|
попробовал уровнять им условия
Добавлено через 14 минут Наоборот хотел сказать )) быстрее if else elsif
0
|
|||||||||||
|
52 / 37 / 9
Регистрация: 13.06.2019
Сообщений: 209
|
|
| 17.05.2020, 14:24 [ТС] | |
|
x_lab,
Модуль Benchmark прекрасен. Возьму на вооружение. Мне кажется, и в моём варианте шансы были те же. Погрешность измерений, из-за того, что я использовал вероятностную функцию, была ничтожной. На моём компе каждая ветвь алгоритма выполнилась равное число раз ± 0.1%, в каждом из трёх вариантов. Быть может на вашем компе, в силу особенностей кэширования, 10 ветвей алгоритма (не сто) - это не достаточно, чтобы множественные сравнения (в среднем 5 на каждый вызов всей конструкции с ветвлением по десяти "направлениям") оказались дороже, чем однократное вычисление позиции в массиве + вызов функции. Предлагаю уровнять шансы так:
... заминочка с proof-of-concept-примерчиком: захотелось сделать в общем виде по числу ветвей. И слегка завис.. NBна досуге проверю - напишу
0
|
|
|
52 / 37 / 9
Регистрация: 13.06.2019
Сообщений: 209
|
||||||
| 22.05.2020, 20:00 [ТС] | ||||||
|
6.pl
здесь два способа "кодогенерации" налету. (кто-нибудь знает как это правильно называется?) 1. шаблон *$имя = \анонимная_ф_ция 2. $ф_ия = eval "sub {}" похоже, мне так кажется, по скорости сгенерированные таким образом ф-ции не будут отличаться от определённых обычным порядком.
0
|
||||||
| 22.05.2020, 20:00 | |
|
Помогаю со студенческими работами здесь
4
Что быстрее switch(enum) или if else? Какая альтернатива есть Какая альтернатива OpenGl? FULL JOIN.... какая альтернатива? Какая конструкция быстрее? Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила»
«Время-Деньги»
«Деньги -Пуля»
|
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|