-2
  • サイズ4の整数をバイト配列に変換しようとしていますが、奇妙な値が得られます。

     byte[] bytes1 = my_int_to_bb_le(196,4);
       public static  byte[] my_int_to_bb_le(int myInteger,int length)
       {
         return ByteBuffer.allocate(length).order(ByteOrder.LITTLE_ENDIAN).putInt(myInteger).array();
       }     
    
  • 出力: -60 0 0 0

  • 必要な出力: 196 0 0 0

    このコードを代替しようとしましたが、同じ出力が得られたため機能しませんでした

    public static byte[] convertIntByteArray(int intval,int len)     
    {       
       byte[] intarray = new byte[len];          
    
       for(int i=0;i<len;i++)        
       {
           if(i==0)
           {
               intarray[i]=(byte)intval;
           }
           else
               intarray[i]=0;        
        } 
        return intarray;     
    }
    
  • 出力: -60 0 0 0

  • 必要な出力: 196 0 0 0

    ありがとう

4

2 に答える 2

3

これは、(符号付き) バイトが間にあるためです。-128 to 127

public class TestNumber{
  public static void main(String[] args){
    byte b1 = -60;
    int b2 = b1 & 0xFF;
    System.out.println("Without casting "+ b1);
    System.out.println("With casting "+b2);
    System.out.println("Bitwise Trickery " + (b1 & 0xFF));
  }
}

数値ごとにメモリ内でビットがどのように配置されているかを確認したい場合は、calc.exeすべての Windows OS に付属の を使用し、 を に変更してviewからProgrammer、数値を入力してそのビット単位の値を確認します。それは私がビット単位の操作に常に使用しているものです:-)

于 2013-02-07T13:39:19.120 に答える
0

次のコマンドを使用して、バイトの符号なし表現を出力できます。

for( byte b : byteArray ) {
    System.out.print((b & 0xFF )+" ");
}

しかし、より一般的には、バイトは、はるかに快適な表示形式のために、ゼロが埋め込まれた16進数として出力されます。

for( byte b : byteArray ) {
    System.out.format("%02X ", b);
}
于 2013-02-07T13:48:44.803 に答える