期待どおりに動作しないテスト コードがいくつかあります。さまざまなサイトや仕様を確認した後でも、何が起こっているのかわかりません。
ここに私のテストコードがあります:
byte[] b = new byte[8];
b[0] = (byte)0x72;
b[1] = (byte)0x3A;
b[2] = (byte)0x60;
b[3] = (byte)0x01;
b[4] = (byte)0x0E;
b[5] = (byte)0x10;
b[6] = (byte)0x8A;
b[7] = (byte)0x11;
String bitmapStr = new String(b);
try {
b = bitmapStr.getBytes("US-ASCII");
} catch (Exception ex) {
ex.printStackTrace();
}
System.out.println("DEBUG: bitmapStr = \"" +bitmapStr + "\"");
for (int i=0; i<=7; i++) {
int byte1 = b[i];
System.out.println("byte"+i + ": " + Integer.toHexString(byte1));
}
プログラムを実行すると、コンソール出力に次のように表示されます。
DEBUG: bitmapStr = "r:`�"
byte0: 72
byte1: 3a
byte2: 60
byte3: 1
byte4: e
byte5: 10
byte6: 3f
byte7: 11
私のバイト配列出力のbyte6、つまりb [6]が0x3Fを出力する方法を確認してください。ただし、0x8Aである必要があります。
理由はありますか?
ちなみに、UTF-8 エンコーディングを使用すると、さらにファンキーな出力が得られます (ASCII は正しいですが)。
UTF-8 文字列エンコーディング出力:
byte0: 72
byte1: 3a
byte2: 60
byte3: 1
byte4: e
byte5: 10
byte6: ffffffef
byte7: ffffffbf