BinaryReader - Считывание одного "БИТА ”?
-
13-11-2019 - |
Вопрос
Кейс :
Снова пытаюсь перехватывать пакеты через мою сетевую карту,
Я разработал 2 расширения для использования при захвате переменного количества битов
public static string ReadBits ( this BinaryReader Key , int Value )
{
BitArray _BitArray = new BitArray ( Value );
for ( int Loop = 0 ; Loop > Value ; Loop++ )
{
/* Problem HERE ---> */ _BitArray [ Loop ] = Key . ReadBoolean ( );
}
return BitConverter . ToString ( _BitArray . ToByteArray ( ) );
}
public static byte [ ] ToByteArray ( this BitArray Key )
{
byte [ ] Value = new byte [ ( int ) Math . Ceiling ( ( double ) Key . Length / 8 ) ];
Key . CopyTo ( Value , 0 );
return Value;
}
Проблема :
_BitArray [ Loop ] = Key . ReadBoolean ( );
Поскольку я пытаюсь прочитать отдельные биты, но ссылаюсь на Документация MSDN,
Это увеличивает позицию потока на 1 БАЙТ , а не на 1 БИТ!!!
Считывает логическое значение из текущего потока и увеличивает текущую позицию потока на единицу байт.
Вопрос :
Могу ли я действительно захватить "ВСЕГО" 1 бит и продвинуть позицию потока на 1 бит?
Пожалуйста, предложите мне решения или идеи :)
С уважением,
Решение
Нет, позиционирование потока основано на byte
шаг.Вы можете написать свою собственную потоковую реализацию с битовым позиционированием.
class BitReader
{
int _bit;
byte _currentByte;
Stream _stream;
public BitReader(Stream stream)
{ _stream = stream; }
public bool? ReadBit(bool bigEndian = false)
{
if (_bit == 8 )
{
var r = _stream.ReadByte();
if (r== -1) return null;
_bit = 0;
_currentByte = (byte)r;
}
bool value;
if (!bigEndian)
value = (_currentByte & (1 << _bit)) > 0;
else
value = (_currentByte & (1 << (7-_bit))) > 0;
_bit++;
return value;
}
}
Другие советы
Нет, это невозможно сделать заранее. Stream
экземпляр на один бит.Наименьшая степень детализации Stream
тип опоры - это один byte
.
Вы могли бы написать оболочку вокруг Stream
который обеспечивает однобитовую детализацию путем манипулирования и кэширования однобайтового перемещения.
class BitStream {
private Stream _stream;
private byte _current;
private int _index = 8;
public byte ReadBit() {
if (_index >= 8) {
_current = _stream.ReadByte();
_index = 0;
}
return (_current >> _index++) & 0x1;
}
}
Примечание:Это позволит разделить байт с правой стороны на биты.Если бы вы хотели читать слева, вам нужно было бы изменить return
линия немного
Считайте 1 байт и преобразуйте его в 8-элементный bool-массив, используя битовые маски