Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.10.02;
Скачать: CL | DM;

Вниз

Как скопировать биты от k до n?   Найти похожие ветки 

 
NikNet ©   (2005-08-21 14:48) [0]

Есть число 9834989832 мне надо из определенной позиций
скопировать до определенной.  Например  от 3 до 8
а также в обратную сторону. Например от 8 до 3.

Помогите реализовать такие ф-ций? Я не умею работать с битами :(


 
Alexander Panov ©   (2005-08-21 15:04) [1]

Наыерное надо учебники почитать?


 
Alexander Panov ©   (2005-08-21 15:05) [2]

Удалено модератором


 
Alexander Panov ©   (2005-08-21 15:06) [3]

Удалено модератором


 
Alexander Panov ©   (2005-08-21 15:06) [4]

Удалено модератором


 
Alexander Panov ©   (2005-08-21 15:07) [5]

Удалено модератором


 
Джо ©   (2005-08-21 15:36) [6]

Автомодератор вернулся? ;)


 
Юрий Зотов ©   (2005-08-21 15:41) [7]

> NikNet ©   (21.08.05 14:48)

Битовые операции основаны на логической (булевой) арифметике. Вот ее основные правила (буква b означает любое значение бита, хоть 0, хоть 1).

b and 0 = 0
b and 1 = b

b or 0 = b
b or 1 = 1

not 0 = 1
not 1 = 0

b xor b = 0
b xor (not b) = 1

Эти правила надо знать наизусть. Еще надо знать, что биты нумеруются от 0 и начиная с младшего.

Итак, нам надо выделить из числа X биты с 3-го по 8-й. Сразу видим, что число X должно занимать не менее 2-х байт, иначе никакого 8-го бита в нем просто не будет. ОК, тогда составим двухбайтовое двоичное число (так называемую маску), в котором биты с 3-го по 8-й равны единице (установлены), а остальные равны нулю (сброшены). Получим 0000000111111000 (а в шестнадцатиричном виде это будет $01F8).

Пусть значение X равно bbbbbbbbbbbbbbbb. Что будет, если произвести операцию AND между этим числом и нашей маской? Давайте посмотрим:

bbbbbbbbbbbbbbbb
and
0000000111111000
=
0000000bbbbbb000

Как видим, в результате мы выделили из числа X биты с 3-го по 8-й - что и требовалось.


 
Anatoly Podgoretsky ©   (2005-08-21 16:18) [8]

Джо ©   (21.08.05 15:36) [6]
Если бы :-)


 
tesseract ©   (2005-08-22 09:37) [9]

>>Как видим, в результате мы выделили из числа X биты с 3-го по 8-й - что и требовалось.
Функция установлен ли бит (номер бита с конца)

Function IsBitSet(value:cardinal; bitno:byte):boolean;
begin
result:=odd(value shr bitno);
end;


перефазировка на номер бита от начала делается так
BitFirst:=SizeOF(cardinal)-bitno;



Страницы: 1 вся ветка

Текущий архив: 2005.10.02;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.05 c
1-1126183793
Толян
2005-09-08 16:49
2005.10.02
подсчет трафика


14-1126351281
palva
2005-09-10 15:21
2005.10.02
Кто пойдет за гробом?


1-1126131889
Delphi_is_cool
2005-09-08 02:24
2005.10.02
Как использовать *.rc


11-1107451723
Kobik
2005-02-03 20:28
2005.10.02
Компонент типа THotKey.


2-1124392185
Urdolphin
2005-08-18 23:09
2005.10.02
Не дай вирусу проникнуть!