Rumah >Java >javaTutorial >Mengapakah penukaran int kepada bait dalam Java menghasilkan nilai negatif, dan bagaimanakah kita boleh mendapatkan semula nilai asal yang tidak ditandatangani?
Anomali Penukaran Int dan Bait yang Menarik
Apabila menukar int kepada bait dalam Java, tingkah laku mungkin kelihatan tidak dijangka, terutamanya apabila mempertimbangkan yang jelas kehilangan data dan tanda negatif yang diberikan kepada bait yang terhasil. Untuk merungkai enigma ini, mari kita mendalami selok-belok jenis data primitif dan perwakilan pelengkap dua.
Memahami Jenis Primitif dan Pelengkap Dua:
Di Java, int menduduki 32 bit, manakala bait menduduki 8 bit sahaja. Selain itu, jenis primitif seperti int dan bait mengikuti perwakilan pelengkap kedua-duanya. Dalam skema ini, bit tertinggi (MSB) menentukan tanda, dan bit tambahan membawa kepada replikasinya.
Penukaran Bitwise dari Int ke Byte:
Apabila menukarkan int ke bait, Java mengekstrak hanya 8 bit paling tidak ketara dan memberikan nilai yang sewajarnya. Walau bagaimanapun, MSB int, kini bit tanda bait, memainkan peranan penting dalam hasilnya.
Mendedahkan Kebenaran Tersembunyi:
Mari kita rungkai contoh yang membingungkan:
int i = 132; byte b = (byte)i; // Implicit narrowing conversion System.out.println(b); // Prints -124
Perwakilan binari 32-bit bagi 132:
00000000000000000000000010000100
Mengekstrak 8 bit paling tidak bererti (10000100):
10000100
Menukar kepada perwakilan pelengkap dua:
11111000
Java mentafsir ini sebagai nilai negatif disebabkan oleh corak bit terbalik, menghasilkan -124 menjadi dicetak.
Menyelesaikan Enigma:
Untuk mendapatkan semula nilai asal 8-bit yang tidak ditandatangani bagi bait, kami boleh melakukan operasi bitwise DAN:
byte signedByte = -124; int unsignedByte = signedByte & 0xff; // 0xff = 11111111b
Operasi ini menutupi bit tanda luar, menghasilkan yang berikut hasil:
Unsigned value: 10000100 (84 in decimal)
Meringkaskan Tipu:
Semasa penukaran int-ke-bait, Java mengabaikan 24 bit paling kiri melalui penyempitan tersirat. Bit tanda, asalnya bit ke-8 dalam int, menjadi MSB dalam bait, mempengaruhi tafsirannya. Untuk mendedahkan nilai yang tidak ditandatangani, operasi AND bitwise diperlukan, memadamkan bit tanda dengan berkesan.
Atas ialah kandungan terperinci Mengapakah penukaran int kepada bait dalam Java menghasilkan nilai negatif, dan bagaimanakah kita boleh mendapatkan semula nilai asal yang tidak ditandatangani?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!