Rumah >Java >javaTutorial >Mengapakah penukaran int kepada bait dalam Java menghasilkan nilai negatif, dan bagaimanakah kita boleh mendapatkan semula nilai asal yang tidak ditandatangani?

Mengapakah penukaran int kepada bait dalam Java menghasilkan nilai negatif, dan bagaimanakah kita boleh mendapatkan semula nilai asal yang tidak ditandatangani?

Susan Sarandon
Susan Sarandonasal
2024-11-09 09:10:02910semak imbas

Why does converting an int to a byte in Java result in a negative value, and how can we retrieve the original unsigned value?

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn