|
0 / 0 / 0
Регистрация: 29.01.2015
Сообщений: 4
|
|
Манипуляции с битами29.01.2015, 20:23. Показов 2867. Ответов 10
Метки нет (Все метки)
В одном из проектов парсятся бинарные данные, среди которых встречается структура вида [длина][данные]. Так вот длина данных может быть записана в 1 - 4 байтах. Чтобы получить [длину], выполняются следующие действия:
1. смотрим первый байт, если старший бит = 0, то [длина] занимает 1 байт. Данный байт приводится к типу UInt32. 2. если старший бит первого байта = 1 , значит [длина] занимает > 1 байта. Смотрим следующий байт, также проверяем значение старшего бита. Если оно опять = 1, то переходим к следующему и т.д. Последним байтом будет байт, в котором значение старшего бита = 0. Допустим количество байтов, которое занимает [длина], определено и = 2 - для примера [ 81 0d ]. Чтобы получить необходимое значение [длины], необходимо убрать старшие биты в байтах, являющиеся по сути флагами. Т.е. для 81 битовая последовательность - 10000001, для 0d - 00001101. Убираем старшие биты: 0000001 и 0001101. Склеиваем: 10001101 - вот это и есть итоговое нужное значение [длина]. Остается теперь его только привести к UInt32. Собственно как реализовать манипуляции с битами и последующее приведение к единому типу UInt32.
0
|
|
| 29.01.2015, 20:23 | |
|
Ответы с готовыми решениями:
10
Манипуляции с массивом Манипуляции с DataGridView |
|
|
|
| 29.01.2015, 22:40 | |
|
0
|
|
|
0 / 0 / 0
Регистрация: 29.01.2015
Сообщений: 4
|
|
| 29.01.2015, 23:18 [ТС] | |
|
Про данные вещи мне известно. Собственно не понятно как перейти к работе с самими битами.
т.е. к примеру как от массива типа byte[] с теми же элементами [ 81 0d ] начать работать с битовой последовательность вида [1000000100001101]. Вот как, скажем так, правильней было бы реализовать этот нюанс? Т.к. в том же BitArray я конструктора, приводящего значения из byte[] или хотя бы из int в битовую последовательность я не нашел.
0
|
|
|
46 / 42 / 14
Регистрация: 18.02.2012
Сообщений: 82
|
|
| 30.01.2015, 00:55 | |
|
0
|
|
|
0 / 0 / 0
Регистрация: 29.01.2015
Сообщений: 4
|
|
| 30.01.2015, 01:04 [ТС] | |
|
Приведите простой пример как побитовыми операторами вырезать 1й и 9й биты из UInt16 [1000000100001101], чтобы стало [0000000010001101].
0
|
|
|
|
|||||||
| 30.01.2015, 01:28 | |||||||
1
|
|||||||
|
46 / 42 / 14
Регистрация: 18.02.2012
Сообщений: 82
|
|||||||||||
| 30.01.2015, 01:29 | |||||||||||
|
Так вырезаем:
0
|
|||||||||||
|
Администратор
|
||||||
| 30.01.2015, 11:00 | ||||||
|
kuzmich, я бы сделал так:
0
|
||||||
|
Почетный модератор
|
|||||||||||
| 30.01.2015, 15:17 | |||||||||||
|
OwenGlendower, у вас будет выход за границы массива, если значение длины будет 0xFFFFFFF.
SetLength
1
|
|||||||||||
|
Администратор
|
|||||||
| 30.01.2015, 20:33 | |||||||
1
|
|||||||
|
0 / 0 / 0
Регистрация: 29.01.2015
Сообщений: 4
|
|
| 31.01.2015, 18:44 [ТС] | |
|
Всем спасибо за помощь, разобрался.
0
|
|
| 31.01.2015, 18:44 | |
|
Помогаю со студенческими работами здесь
11
Манипуляции с массивом Манипуляции с картинкой Манипуляции с формой
Манипуляции с формами Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение:
DISM / Online / Add-Capability / CapabilityName:WMIC~~~~
Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
|
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача: при создании документов установить период списания автоматически. . .
|
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2.
Задача: вывести данные из ТЧ нетипового документа. . .
|
Функция заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению.
На форме документа создается. . .
|
|
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
|
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
|
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
|
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию.
2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
|