Понедельник, 29 Апр 2024, 14:10
Uchi.ucoz.ru
Меню сайта
Форма входа

Категории раздела
Высшая математика [11]
Экономическая социология [95]
Основы Менеджмента [64]
Бухгалтерский учёт [157]
Философия [163]
Мировая Экономика [603]
Бизнес планирование [29]
Финансирование и кредитование инвест [105]
Ценообразование [46]
Гражданское право [196]
Права Человека [173]
Основы Маркетинга [207]
Основы энергосбережения [55]
Информатика [0]
Экология и устойчивое развитие [0]
Физика для студентов [0]
Основы права [0]
Политология [0]
Не стандартные примеры на Delphi [169]
Примеры на Delphi7 [108]
Алгоритмы [94]
API [110]
Pascal [152]
Базы Данных [6]
Новости
Чего не хватает сайту?
500
Статистика
Зарегистрировано на сайте:
Всего: 51635


Онлайн всего: 4
Гостей: 4
Пользователей: 0
Яндекс.Метрика
Рейтинг@Mail.ru

Каталог статей


Главная » Статьи » Студентам » Алгоритмы

Манипулирование битами
Ок, я покажу как можно это сделать на примере 4 битов. Битовые
маски обычно используются в некоторых специфических свойствах.
Для 4-битных чисел максимальное значение равно 1+2+4+8 = 15 (или 1111). Если
свойство будет использовать биты как флажки ( 1 = True, 0 = False), то для
каждой комбинации флажков результирующее число будет всегда уникальным.

Теперь поставим перед собой задачу определения статуса отдельного бита.
Довольно муторным выглядит для такой задачи преобразования битов в десятичное
число. Пойдем другим путем. Возьмем число, скажем 7 (0111), и попробуем
выставить ему третий справа бит. Значение для проверки - 0100 (4 десятичное).

Итак, мы сравниваем две величины - 0100 и 0111, бит за битом. Вот некоторая
"кухня" работы операторов, выполняющих битовые команды:

0100 0111

4 AND 7 = 0100 (4)
(=4, т.к. бит, который мы хотим выставить, устанавливается в 1)
4 OR 7 = 0111 (7)
(не так много в этом примере)
4 XOR 7 = 0011 (3)
Если вы следуете за ходом моей
мысли, то вы поймете, почему я начал с операции AND. Так как мы точно знаем, что
идет проверка на выставленность единственного бита, который должен быть
установлен в сравниваемом значении, то возможный результат может быть только 0
или (как в показанном примере) 4.

Итак, ваш код должен быть следующим:

If (YourCheckVar AND 4) = 4 Then
3-й бит установлен
Else
3-й бит не установлен;
Категория: Алгоритмы | Добавил: Lerka (21 Ноя 2012)
Просмотров: 514 | Рейтинг: 1.0/ 5 Оштрафовать | Жаловаться на материал
Похожие материалы
Всего комментариев: 0

Для блога (HTML)


Для форума (BB-Code)


Прямая ссылка

Профиль
Понедельник
29 Апр 2024
14:10


Вы из группы: Гости
Вы уже дней на сайте
У вас: непрочитанных сообщений
Добавить статью
Прочитать сообщения
Регистрация
Вход
Улучшенный поиск
Поиск по сайту Поиск по всему интернету
Наши партнеры
Интересное
Популярное статьи
Портфолио ученика начальной школы
УХОД ЗА ВОЛОСАМИ ОЧЕНЬ ПРОСТ — ХОЧУ Я ЭТИМ ПОДЕЛИТ...
Диктанты 2 класс
Детство Л.Н. Толстого
Библиографический обзор литературы о музыке
Авторская программа элективного курса "Практи...
Контрольная работа по теме «Углеводороды»
Поиск
Главная страница
Используются технологии uCoz