Как преобразовать байт в его двоичное строковое представление
Например, биты в байте B
равны 10000010
, как я могу назначить биты в строке str
буквально, то есть str = "10000010"
.
Edit
Я прочитал байт из двоичного файла и сохранил его в массиве байтов B
. Я использую System.out.println(Integer.toBinaryString(B[i]))
. проблема
(a), когда бит начинается с (leftmost) 1, результат неверен, поскольку он преобразует B[i]
в отрицательное значение int.
(b) если бит начинается с 0
, то проигнорировать вывод 0
, например, предположим, что B[0]
имеет 00000001, выход 1
вместо 00000001
Ответы
Ответ 1
Используйте Integer#toBinaryString()
:
byte b1 = (byte) 129;
String s1 = String.format("%8s", Integer.toBinaryString(b1 & 0xFF)).replace(' ', '0');
System.out.println(s1); // 10000001
byte b2 = (byte) 2;
String s2 = String.format("%8s", Integer.toBinaryString(b2 & 0xFF)).replace(' ', '0');
System.out.println(s2); // 00000010
DEMO.
Ответ 2
Я использовал это. Идея похожа на другие ответы, но нигде не видел точного подхода :)
System.out.println(Integer.toBinaryString((b & 0xFF) + 0x100).substring(1));
0xFF
- 255 или 11111111
(максимальное значение для байта без знака). 0x100
- это 256 или 100000000
&
Переводит байт в целое число. В этот момент это может быть что угодно от 0
255
(от 00000000
до 11111111
, я исключил первые 24 бита). + 0x100
.substring(1)
и .substring(1)
гарантируют, что будут .substring(1)
нули.
Я рассчитал время по сравнению с ответом Жоао Силвы, и это в 10 раз быстрее. http://ideone.com/22DDK1 Я не включил ответ Pshemo, так как он не дополняет должным образом.
Ответ 3
Это то, что вы ищите?
преобразование из строки в байт
byte b = (byte)(int)Integer.valueOf("10000010", 2);
System.out.println(b);// output -> -126
преобразование из байта в строку
System.out.println(Integer.toBinaryString((b+256)%256));// output -> "10000010"
Или, как сказал Жуан Силва в своем комментарии, чтобы добавить начальный 0
мы можем отформатировать строку до длины 8 и заменить результирующие начальные пробелы на ноль, поэтому в случае строки типа " 1010"
мы получим "00001010"
System.out.println(String.format("%8s", Integer.toBinaryString((b + 256) % 256))
.replace(' ', '0'));
Ответ 4
Вы можете проверить каждый бит в байте, а затем добавить 0 или 1 в строку. Вот небольшой вспомогательный метод, который я написал для тестирования:
public static String byteToString(byte b) {
byte[] masks = { -128, 64, 32, 16, 8, 4, 2, 1 };
StringBuilder builder = new StringBuilder();
for (byte m : masks) {
if ((b & m) == m) {
builder.append('1');
} else {
builder.append('0');
}
}
return builder.toString();
}
Ответ 5
Этот код продемонстрирует, как java int можно разделить на 4 последовательных байта.
Затем мы можем проверить каждый байт с использованием методов Java по сравнению с низкоуровневым байтовым/битным опросом.
Это ожидаемый результат при запуске кода ниже:
[Input] Integer value: 8549658
Integer.toBinaryString: 100000100111010100011010
Integer.toHexString: 82751a
Integer.bitCount: 10
Byte 4th Hex Str: 0
Byte 3rd Hex Str: 820000
Byte 2nd Hex Str: 7500
Byte 1st Hex Str: 1a
(1st + 2nd + 3rd + 4th (int(s)) as Integer.toHexString: 82751a
(1st + 2nd + 3rd + 4th (int(s)) == Integer.toHexString): true
Individual bits for each byte in a 4 byte int:
00000000 10000010 01110101 00011010
Вот код для запуска:
public class BitsSetCount
{
public static void main(String[] args)
{
int send = 8549658;
System.out.println( "[Input] Integer value: " + send + "\n" );
BitsSetCount.countBits( send );
}
private static void countBits(int i)
{
System.out.println( "Integer.toBinaryString: " + Integer.toBinaryString(i) );
System.out.println( "Integer.toHexString: " + Integer.toHexString(i) );
System.out.println( "Integer.bitCount: "+ Integer.bitCount(i) );
int d = i & 0xff000000;
int c = i & 0xff0000;
int b = i & 0xff00;
int a = i & 0xff;
System.out.println( "\nByte 4th Hex Str: " + Integer.toHexString(d) );
System.out.println( "Byte 3rd Hex Str: " + Integer.toHexString(c) );
System.out.println( "Byte 2nd Hex Str: " + Integer.toHexString(b) );
System.out.println( "Byte 1st Hex Str: " + Integer.toHexString(a) );
int all = a+b+c+d;
System.out.println( "\n(1st + 2nd + 3rd + 4th (int(s)) as Integer.toHexString: " + Integer.toHexString(all) );
System.out.println("(1st + 2nd + 3rd + 4th (int(s)) == Integer.toHexString): " +
Integer.toHexString(all).equals(Integer.toHexString(i) ) );
System.out.println( "\nIndividual bits for each byte in a 4 byte int:");
/*
* Because we are sending the MSF bytes to a method
* which will work on a single byte and print some
* bits we are generalising the MSF bytes
* by making them all the same in terms of their position
* purely for the purpose of printing or analysis
*/
System.out.print(
getBits( (byte) (d >> 24) ) + " " +
getBits( (byte) (c >> 16) ) + " " +
getBits( (byte) (b >> 8) ) + " " +
getBits( (byte) (a >> 0) )
);
}
private static String getBits( byte inByte )
{
// Go through each bit with a mask
StringBuilder builder = new StringBuilder();
for ( int j = 0; j < 8; j++ )
{
// Shift each bit by 1 starting at zero shift
byte tmp = (byte) ( inByte >> j );
// Check byte with mask 00000001 for LSB
int expect1 = tmp & 0x01;
builder.append(expect1);
}
return ( builder.reverse().toString() );
}
}
Ответ 6
Получить каждый бит байта и преобразовать в строку.
У байта есть 8 бит, и мы можем получить их один за другим через бит. Например, мы перемещаем второй бит байта 6 бит вправо, второй бит в конце бит из 8 бит, затем и (&) с 0x0001 для очистки передних бит.
public static String getByteBinaryString(byte b) {
StringBuilder sb = new StringBuilder();
for (int i = 7; i >= 0; --i) {
sb.append(b >>> i & 1);
}
return sb.toString();
}
Ответ 7
Извините, я знаю, что уже немного поздно... Но у меня есть намного более простой способ...
В двоичную строку:
//Add 128 to get a value from 0 - 255
String bs = Integer.toBinaryString(data[i]+128);
bs = getCorrectBits(bs, 8);
метод getCorrectBits:
private static String getCorrectBits(String bitStr, int max){
//Create a temp string to add all the zeros
StringBuilder sb = new StringBuilder();
for(int i = 0; i < (max - bitStr.length()); i ++){
sb.append("0");
}
return sb.toString()+ bitStr;
}
Ответ 8
Integer.toBinaryString((byteValue & 0xFF) + 256).substring(1)
Ответ 9
String byteToBinaryString(byte b){
StringBuilder binaryStringBuilder = new StringBuilder();
for(int i = 0; i < 8; i++)
binaryStringBuilder.append(((0x80 >>> i) & b) == 0? '0':'1');
return binaryStringBuilder.toString();
}
Ответ 10
Мы все знаем, что в Java нет ничего похожего на ключевое слово unsigned. Кроме того, byte
примитив в соответствии со спецификацией Java представляет значение от −128
до 127
. Например, если byte
cast
к int
Java будет интерпретировать первый bit
как sign
и использовать расширение знака.
Тогда как преобразовать байт больше 127
в его двоичное представление строки?
Ничто не мешает вам просматривать byte
просто как 8- byte
и интерпретировать эти биты как значение между 0
и 255
. Кроме того, вам нужно помнить, что вы ничего не можете сделать, чтобы навязать свою интерпретацию кому-то еще. Если метод принимает byte
, то этот метод принимает значение от −128
до 127
если явно не указано иное.
Поэтому лучший способ решить эту проблему - преобразовать значение byte
значение int
, вызвав метод Byte.toUnsignedInt()
или Byte.toUnsignedInt()
его к типу int
primitive (int) signedByte & 0xFF
. Вот вам пример:
public class BinaryOperations
{
public static void main(String[] args)
{
byte forbiddenZeroBit = (byte) 0x80;
buffer[0] = (byte) (forbiddenZeroBit & 0xFF);
buffer[1] = (byte) ((forbiddenZeroBit | (49 << 1)) & 0xFF);
buffer[2] = (byte) 96;
buffer[3] = (byte) 234;
System.out.println("8-bit header:");
printBynary(buffer);
}
public static void printBuffer(byte[] buffer)
{
for (byte num : buffer) {
printBynary(num);
}
}
public static void printBynary(byte num)
{
int aux = Byte.toUnsignedInt(num);
// int aux = (int) num & 0xFF;
String binary = String.format("%8s', Integer.toBinaryString(aux)).replace(' ', '0');
System.out.println(binary);
}
}
Выход
8-bit header:
10000000
11100010
01100000
11101010
Ответ 11
Просто угадать здесь, но если у вас есть байт, вы не могли бы просто вызвать toString() на объекте, чтобы получить значение? Или, взглянув на api, используя byteValue()?