Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

 
 
Опции темы Поиск в этой теме Опции просмотра
  #4  
Старый 11.03.2009, 16:13
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,093
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Ну, думать лень.
Принцип тот же, что ты использовал в своем коде, где у тебя xor стоит.
Я тебе просто пример в двоичном коде приведу (коротком, меняем 2 бита).

Код:
N := 01010101; // Исходное число
M1 := 00001100; // Первая маска - выделение нужной части.
N1 := N AND M1; // Выделили нужное число. N1 = 00000100
N2 := NOT N1; // Инвертировали N2 := 11111011
N21 := N2 AND 00001100; // сбросили ненужны биты.
M2 := 11110011; // вторая маска - только обнулили заменяемый кусок
N3 := N AND M2; // данные с обнуленном нашим куском N3 = 01010001
N4 := N3 OR N21; // объединили данные N21 и N3. N4 = 01011001 - искомый результат.

Естественно, это не готовый код, а демонстрация принципа. Здесь инвертируется некоторый байт не на прямую, а путем его выделения, инвертирования отдельно, а потом вставки обратно. Т.е. нужные данные можно получить любым другим образом. Важен процесс вставки.
Я специально использовал только набор базовых операторов (AND, OR, NOT), что бы было понятнее.
Ответить с цитированием
 


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

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

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 00:05.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025