整数をバイト配列に変換(Java)


137

をに変換する最も速い方法IntegerByte Array何ですか?

例えば 0xAABBCCDD => {AA, BB, CC, DD}


1
結果のバイト配列がどのような形式であるかは重要ですか?あなたはそれで何をしますか?
skaffman 2009

回答:


237

ByteBufferクラスを見てください。

ByteBuffer b = ByteBuffer.allocate(4);
//b.order(ByteOrder.BIG_ENDIAN); // optional, the initial order of a byte buffer is always BIG_ENDIAN.
b.putInt(0xAABBCCDD);

byte[] result = b.array();

バイト順序を設定すると、そのを確保しresult[0] == 0xAAresult[1] == 0xBBresult[2] == 0xCCresult[3] == 0xDD

または、手動で行うこともできます。

byte[] toBytes(int i)
{
  byte[] result = new byte[4];

  result[0] = (byte) (i >> 24);
  result[1] = (byte) (i >> 16);
  result[2] = (byte) (i >> 8);
  result[3] = (byte) (i /*>> 0*/);

  return result;
}

ByteBufferクラスは、しかし、そのような汚れた手の仕事のために設計されました。実際、private java.nio.Bitsはこれらによって使用されるヘルパーメソッドを定義しますByteBuffer.putInt()

private static byte int3(int x) { return (byte)(x >> 24); }
private static byte int2(int x) { return (byte)(x >> 16); }
private static byte int1(int x) { return (byte)(x >>  8); }
private static byte int0(int x) { return (byte)(x >>  0); }

3
これは、バイトバッファがすでに存在する場合はうまく機能します...そうでない場合は、長さ4のバイト配列を割り当てて手動でシフトを行うよりも、割り当てを行うのに時間がかかるようです...小さな違いについて。
Jason S、

ByteBufferインスタンスはキャッシュできます。そして内部的には、とにかくシフトとマスキングで確実に実装されています。
Gregory Pakosz、2009

4
これは完全に良い答えです。ビッグエンディアンが指定されたデフォルトであり、メソッドは「チェーン可能」であり、位置引数はオプションであるため、すべて次のようになります:byte [] result = ByteBuffer.allocate(4).putInt(0xAABBCCDD).array( ); もちろん、これを繰り返してすべての結果を連結する場合(これはこの種のことを行う場合に一般的です)、単一のバッファーを割り当てて、必要なすべてのものを繰り返しputFoo()します-あなたが行くにつれてそれはオフセットを追跡します。本当に便利なクラスです。
Kevin Bourrillion、2009

それは署名された型に何をもたらしますか?
グレゴリーパコス

3
知らない人のために。putIntは、入力整数のサイズに関係なく、常に4バイトを書き込みます。2バイトだけが必要な場合は、putShortなどを使用します...
bvdb

36

使用BigInteger

private byte[] bigIntToByteArray( final int i ) {
    BigInteger bigInt = BigInteger.valueOf(i);      
    return bigInt.toByteArray();
}

使用DataOutputStream

private byte[] intToByteArray ( final int i ) throws IOException {      
    ByteArrayOutputStream bos = new ByteArrayOutputStream();
    DataOutputStream dos = new DataOutputStream(bos);
    dos.writeInt(i);
    dos.flush();
    return bos.toByteArray();
}

使用ByteBuffer

public byte[] intToBytes( final int i ) {
    ByteBuffer bb = ByteBuffer.allocate(4); 
    bb.putInt(i); 
    return bb.array();
}

5
ただし、バイトオーダーに注意してください
グレゴリーパコス2009

1
ByteBufferはunsigned intを提供しますか?
アルンジョージ

@Pascal ByteBufferを使用してByteBufferで試しましたbb = ByteBuffer.allocate(3); このため、java.nio.BufferOverflowExceptionが発生していますが、4未満の値で機能しない理由がわかりません。説明していただけますか?
Sanjay Jain 2015

@SanjayJain Javaのintは32ビットまたは4バイトのサイズであるため、ByteBufferに少なくとも4バイトのメモリを割り当てる必要があるため、バッファオーバーフロー例外が発生します。
2017

@GregoryPakoszはバイトオーダーに関して正しいです。使用して彼の答えはByteBuffer1 -あなたは2 ^ 31よりもint型の大きなを扱っている場合は、より直感的である
ordonezalex

31

この機能を使用してください

public byte[] toByteArray(int value) {
    return new byte[] {
            (byte)(value >> 24),
            (byte)(value >> 16),
            (byte)(value >> 8),
            (byte)value};
}

intをバイト値に変換します


また、これが最も重要なビットに関係なく機能し、他の回答と比較してより効率的であることは何の価値もありません。「>>」も使用できます。
12

1
このような直接的な解決策は、ライブラリメソッドを呼び出すよりも確かに高速です。ライブラリメソッド呼び出しの余分なオーバーヘッドをすべて負担するのではなく、数行のコードで直接ビットをいじる必要がある場合があります。
David R Tribble、2016

そして、これは言語間でうまく変換するので、多言語ソフトウェア開発に適しています。
コーディネーター

15

Guavaが好きな場合は、そのIntsクラスを使用できます。


以下の場合intbyte[]使用toByteArray()

byte[] byteArray = Ints.toByteArray(0xAABBCCDD);

結果は{0xAA, 0xBB, 0xCC, 0xDD}です。


その逆はfromByteArray()またはfromBytes()

int intValue = Ints.fromByteArray(new byte[]{(byte) 0xAA, (byte) 0xBB, (byte) 0xCC, (byte) 0xDD});
int intValue = Ints.fromBytes((byte) 0xAA, (byte) 0xBB, (byte) 0xCC, (byte) 0xDD);

結果は0xAABBCCDDです。


8

使用できますBigInteger

整数から:

byte[] array = BigInteger.valueOf(0xAABBCCDD).toByteArray();
System.out.println(Arrays.toString(array))
// --> {-86, -69, -52, -35 }

返される配列は、数値を表すために必要なサイズであるため、たとえば1を表すためにサイズ1になる可能性があります。ただし、intが渡される場合、サイズは4バイトを超えることはできません。

文字列から:

BigInteger v = new BigInteger("AABBCCDD", 16);
byte[] array = v.toByteArray();

ただし、最初のバイトが0x7F(この場合のように)高い場合は、BigIntegerが配列の先頭に0x00バイトを挿入することに注意する必要があります。これは、正の値と負の値を区別するために必要です。


ありがとう!しかし、これはBigIntegerなので、intは正しくラップアラウンドしますか?それはInteger.MAX_VALUEの外にある整数ですが、それでも4バイトのみで表すことができますか?
バターカップ

1
これは確かに実行が速くありません。;)
Peter Lawrey、

これは良いオプションではありません。0x00バイトを追加するだけでなく、先行ゼロを取り除くこともあります。
ZZ Coder

1

ByteOrderを適切に処理するシンプルなソリューション:

ByteBuffer.allocate(4).order(ByteOrder.nativeOrder()).putInt(yourInt).array();


1

アンドロイドでとても簡単

int i=10000;
byte b1=(byte)Color.alpha(i);
byte b2=(byte)Color.red(i);
byte b3=(byte)Color.green(i);
byte b4=(byte)Color.blue(i);

1

これはあなたを助けます。

import java.nio.ByteBuffer;
import java.util.Arrays;

public class MyClass
{
    public static void main(String args[]) {
        byte [] hbhbytes = ByteBuffer.allocate(4).putInt(16666666).array();

        System.out.println(Arrays.toString(hbhbytes));
    }
}

0

シフトすることもできます-

byte[] ba = new byte[4];
int val = Integer.MAX_VALUE;

for(byte i=0;i<4;i++)
    ba[i] = (byte)(val >> i*8);
    //ba[3-i] = (byte)(val >> i*8); //Big-endian

0

これは、適切に機能するメソッドです。

public byte[] toByteArray(int value)
{
    final byte[] destination = new byte[Integer.BYTES];
    for(int index = Integer.BYTES - 1; index >= 0; index--)
    {
        destination[i] = (byte) value;
        value = value >> 8;
    };
    return destination;
};

0

それは私の解決策です:

public void getBytes(int val) {
    byte[] bytes = new byte[Integer.BYTES];
    for (int i = 0;i < bytes.length; i ++) {
        int j = val % Byte.MAX_VALUE;
        bytes[i] = (j == 0 ? Byte.MAX_VALUE : j);
    }
}

また、Stringyメソッド:

public void getBytes(int val) {
    String hex = Integer.toHexString(val);
    byte[] val = new byte[hex.length()/2]; // because byte is 2 hex chars
    for (int i = 0; i < hex.length(); i+=2)
        val[i] = Byte.parseByte("0x" + hex.substring(i, i+2), 16);
    return val;
}
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.