Java에서 "value & 0xff"의 흥미로운 사례 이해
Java에서 일반적으로 사용되는 비트 AND 연산자 "&"는 두 정수에 대한 비트 연산을 수행하여 정수 값을 얻습니다. 그러나 쿼리 "value & 0xff"와 같이 바이트에 적용하면 정수 결과가 반환되어 많은 사람들이 당황합니다.
이 미스터리를 풀기 위해 Java 바이트 데이터 유형의 기본 사항을 살펴보겠습니다. 다른 숫자 유형과 달리 바이트는 부호가 있으므로 양수와 음수를 모두 나타낼 수 있습니다. 이러한 구별은 비트 연산을 수행할 때 매우 중요합니다.
주어진 코드에서 "value & 0xff"는 본질적으로 16진수 리터럴과 함께 비트 AND 연산을 적용하여 부호 있는 바이트 "value"를 부호 없는 정수 "결과"로 변환합니다. 0xff(255). 이 작업을 수행하면 "값"의 가장 낮은 8비트만 "결과"에 유지되어 음수 부호 확장을 효과적으로 제거할 수 있습니다.
이러한 변환의 필요성은 "값"이 부호 있는 비트라는 사실에서 비롯됩니다. 바이트이고 "&" 연산자에는 정수 피연산자가 필요합니다. 바이트 "값"은 작업 중에 자동으로 int로 승격되어 32비트 부호 있는 정수가 됩니다. 결과적으로 승격된 int 값에 대해 "&" 연산이 수행되고 결과는 원래 바이트의 최하위 8비트를 유지하면서 다시 int로 변환됩니다.
예를 들어, "value"에 11111110(부호 있는 바이트로 -2를 나타냄)의 이진 표현인 경우 "value & 0xff" 작업은 결과로 11111110(부호 없는)을 생성합니다. 이는 16진수 리터럴 0xff가 11111111의 이진수 표현을 가지며 이 두 값의 비트 AND가 최하위 비트 8개를 제외한 모든 비트를 효과적으로 0으로 설정하기 때문입니다.
위 내용은 \"value & 0xff\"가 Java 바이트를 부호 없는 정수로 변환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!