Телесистемы
 Разработка, производство и продажа радиоэлектронной аппаратуры
На главную   | Карта сайта | Пишите нам | В избранное
Требуется программист в Зеленограде
- обработка данных с датчиков; ColdFire; 40 тыс.
e-mail:jobsmp@pochta.ru

Телесистемы | Электроника | Конференция «Микроконтроллеры и их применение»

Можно, но будет медленно. Самый тупой способ могу подсказать, но чисто примерно, как принцип, а реализацию надо проверить. >>

Отправлено VasilyS (80.92.96.25) 14 июня 2010, г. 11:37
В ответ на: Как правильно организовать побитное хранение и поиск данных по заданной маске (см. внутри) отправлено ZoltriX 14 июня 2010, г. 10:21

1. Значит, у тебя всего 256 бит. Это массив char Array[32]
2. Организуешь макрос возвращающий бит. Примерно так
#define GET_BIT( n ) (((Array[(n)>>3 ]) & (1 << ((n) & 0x07))) ? \
( 1 ) : ( 0 ) )
3. Поиск байта-маски по массиву:
char x = 0, sovpadenie = 0;
do{
if( ( (GET_BIT(x) << 7) == (Mask & 0x80) ) &&
( (GET_BIT(x) << 6) == (Mask & 0x40) ) &&
.... и так весь байт
( (GET_BIT(x) << 0) == (Mask & 0x01) ) )
{
sovpadenie = 1;
break; //Есть совпадение начиная с бита x !!!
}
x++;
}wbile( x < 249)
if( sovpadenie != 0) ..........


Составить ответ | Вернуться на конференцию

Ответы


Отправка ответа
Имя*: 
Пароль: 
E-mail: 
Тема*:

Сообщение:

Ссылка на URL: 
URL изображения: 

если вы незарегистрированный на форуме пользователь, то
для успешного добавления сообщения заполните поле, как указано ниже:
введите число 69:

Перейти к списку ответов | Конференция | Раздел "Электроника" | Главная страница | Карта сайта

Rambler's Top100 Рейтинг@Mail.ru
 
Web telesys.ru