меня есть 41 тревога, тревоги приходят в uint16_t, мне надо эти 41 тревоги разбить на 3 группы и передавать побитово в юинт 16, то есть я выделяю по 14 бит на 14 тревог, 2 бита на номер группы. Делать 14 case так себе кажется идея, создавать 14 массивов по 3 тревоги то же не очень нравится.
Идея в том, чтоб передать номер тревоги в функцию, а он на выходе дал номер бита на который надо делать смещение.
Как можно лучше обыграть?
>14 case так себе кажется идея вроде бы наиболее адекватное решение
я еще думаю про двумерный массив Разбить группы по минимальному номеру тревоги Вот портянка большая 14 кейсов выглядит так себе Но больше в голове идей нет
%14 (младшие биты) - номер тревоги (... >>14) & 0х3 - номер группы.
Или уточни задачу - неоч. понятно.
Можно сконволить код тревоги в индекс массива. В массивах указатели на ф-цию обработчик
Лучше не мудрить и вычленять по маске, как выше предложили. Магия препроцессора сделает всё за тебя)
Смотри есть тревоги, у них номер прилетает в 2 байтах. Этот номер тревоги надо засунуть в бит. То есть первая группа это от 1-14 приходит в 2 байтах, от номера тревоги надо выставить бит в 2х байтном слове. Это первая группа. Во второй группе 16,17,18,29,37,44,45,46,47,48,50,52,58,60 Это надо записать так же в 2 байтное слово, но выставить нужный бит от 2 группы. Так же 14 тревог. И их в 14 бит записать И 3 группа похожее. Я пока вижу решение писать портянку из кейсов Прилетает код тревоги 10 выставить 10 бит в 1 Прилетает 17 выставить 2 бит в 1
битовые поля, если компилятор не сделает таблицу из свитч-кейза, сделать ее руками. быстро, и нет еб..ли с битами. если нужна кроссплатформенность, будет ifdef для порядка байт
сделай константный массив который будет отображать входные чиселки в номера битов выходных
то есть от кода тревоги, выходной бит?
Что-то я не допираю, как номер тревоги в выходной бит в массиве закодировать
Количеством сдвигов влево
Обсуждают сегодня