자바 int 란 무엇입니까?
Java에서는 int가 32비트로 표현되고, long이 64비트로 표현됩니다. 이 두 가지 기본 유형은 정수이며 다른 표현 방법이 없습니다. 그들은 내부적으로 어떻게 자신을 표현합니까? 2의 보수 코드로 표현됩니다. 문제를 해결하면서 Java의 비트 연산을 자주 접하게 되므로 Java의 비트 연산은 int 및 long 유형에만 사용할 수 있습니다. 따라서 우리는 Java가 내부적으로 바이너리로 어떻게 표현되는지 분석할 이유가 있습니다. 여기서는 int를 예로 들었습니다. long도 마찬가지입니다.
1. int
int의 범위는 Java 내부적으로 32비트로 표현되며, 가장 높은 비트는 기호를 나타내므로 실제로 표현할 수 있는 숫자는 31비트이다. 자바 int형의 값 범위는 -2^31~2^31-1입니다.
범위가 왜 이렇죠? 여기에는 바이너리 저장 방법이 포함됩니다.
Java에서는 2의 보수를 사용하여 int를 저장합니다. 양수의 경우 보수는 그 자체입니다. 예를 들어 4비트를 예로 들어보겠습니다. 양수 1-7의 경우 각각 0001,0010입니다. . . , 0111, 총 7개의 숫자로 2^3-1입니다.
0의 경우 문제가 발생하고 있음을 알 수 있습니다. -0 또는 +0일 수 있으며 둘 다 0입니다. 0을 표현하는 방법을 결정 하시겠습니까? 보수 부호의 법칙에 따르면 0은 +0으로 간주되므로 0은 0000으로 표시됩니다.
이때 음수 표현이 필요합니다. 우리는 음수의 보수 표현이 절대값의 반전(부호 비트와 함께 반전됨)에 1을 더한 것이라고 믿습니다. 예를 들어 -5의 경우 절대값은 5이므로 0101로 표현됩니다. 이를 반전하면 1010이 되고 더하기 1은 1011이 됩니다. 이것이 -5의 보수 표현입니다.
이때 1000을 사용하면 -8을 나타낼 수 있으므로 음수의 범위는 -2^31이며 이는 int의 값 범위도 설명합니다. 64비트 길이의 경우에도 마찬가지입니다.
2. Java의 비트 연산
Java의 비트 연산은 어떻게 수행되나요? 시프트 연산은 전체 숫자를 전체적으로 왼쪽이나 오른쪽으로 이동한다는 점을 기억하세요. 왼쪽으로 이동하면 하위 비트가 0으로 채워집니다. 오른쪽으로 이동하면 두 가지 상황이 발생합니다. 0이고 양수이면 상위 비트는 0으로 채워집니다. 음수인 경우 상위 비트는 1로 채워집니다. 예를 들어 -5는 1011이고 오른쪽으로 한 자리 이동하면 1101, 즉 -3이 됩니다.
약간의 조작도 있습니다. 비트 연산인 경우 부호 비트도 포함되어야 한다는 점을 기억하세요!
3. 오른쪽 쉬프트와 나눗셈의 관계
양수(물론 0도 마찬가지)의 경우 한 자리 오른쪽으로 이동하면 2로 나눈 결과와 같지만 음수의 경우에는 not (정확하게는 2로 나누기) 결과는 -1)! 예를 들어, -5/2의 결과는 -2이고, -5>>1의 결과는 -3입니다.
4 양수 및 음수 부호와 정수 나누기 및 나머지 연산의 관계
양수/양수, 반내림
음수/음수, 절대값의 나눗셈과 동일
양수/ 음수와 음수/양수는 음수 부호로 나눈 절대값입니다.
% 결과의 경우 결과의 절대값은 절대값의 계수와 동일하지만 부호는 첫 번째 숫자에 따라 결정됩니다.
5. 보완코드를 사용하는 이유는 무엇인가요?
(1) 앞서 언급했듯이 +0과 -0을 합리적으로 표현하기 위해
(2) 음수에 음수를 하나 더 표현할 수 있습니다.
(3) 기호는 다음과 같습니다. 비트는 동시에 다른 비트와 동일하게 처리되며, 뺄셈도 덧셈으로 처리될 수 있습니다. 또한, 2의 보수로 표현된 두 수를 더할 때 최상위 비트(부호 비트)에 캐리가 있으면 그 캐리를 버린다.
사실 가장 큰 이유는 덧셈과 뺄셈의 계산을 쉽게 하기 위해서입니다. 연산을 위해 2의 보수 시스템을 사용할 때 부호 비트를 함께 추가하여 연산할 수 있습니다. 비트 연산에서 부호 비트에 캐리가 있으면 비트 범위를 초과했기 때문에 폐기될 수 있습니다. 양수와 그 덧셈에는 특별한 것이 없습니다. 아래 예시는 모두 8비트입니다. 예를 들어 7+7(00000111+00000111)의 경우 결과는 00001110(14)입니다.
예를 들어 9-4의 뺄셈은 9+(-4)라고 생각합니다. 먼저 4인 00000100을 반전하고 1을 더해 11111100을 나타내는 -4의 보수를 얻은 다음 더합니다. , 즉
+00001001(9)
+11111100(-4)
? 100000101
마지막 부호 비트의 캐리 1이 비트 범위를 초과했으므로 직접 폐기하고 5를 직접 얻을 수 있습니다. 그래서 뺄셈이 덧셈으로 바뀌는 것을 실현한 것입니다.
위 내용은 자바 int 란 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











일부 애플리케이션이 제대로 작동하지 않는 회사의 보안 소프트웨어에 대한 문제 해결 및 솔루션. 많은 회사들이 내부 네트워크 보안을 보장하기 위해 보안 소프트웨어를 배포 할 것입니다. ...

시스템 도킹의 필드 매핑 처리 시스템 도킹을 수행 할 때 어려운 문제가 발생합니다. 시스템의 인터페이스 필드를 효과적으로 매핑하는 방법 ...

데이터베이스 작업에 MyBatis-Plus 또는 기타 ORM 프레임 워크를 사용하는 경우 엔티티 클래스의 속성 이름을 기반으로 쿼리 조건을 구성해야합니다. 매번 수동으로 ...

IntellijideAultimate 버전을 사용하여 봄을 시작하십시오 ...

많은 응용 프로그램 시나리오에서 정렬을 구현하기 위해 이름으로 이름을 변환하는 솔루션, 사용자는 그룹으로, 특히 하나로 분류해야 할 수도 있습니다.

Java 객체 및 배열의 변환 : 캐스트 유형 변환의 위험과 올바른 방법에 대한 심층적 인 논의 많은 Java 초보자가 객체를 배열로 변환 할 것입니다 ...

데이터베이스 쿼리에 tkmyBatis를 사용하는 경우 쿼리 조건을 구축하기 위해 엔티티 클래스 변수 이름을 우아하게 가져 오는 방법이 일반적인 문제입니다. 이 기사는 고정 될 것입니다 ...

전자 상거래 플랫폼에서 SKU 및 SPU 테이블의 디자인에 대한 자세한 설명이 기사는 전자 상거래 플랫폼에서 SKU 및 SPU의 데이터베이스 설계 문제, 특히 사용자 정의 판매를 처리하는 방법에 대해 논의 할 것입니다 ...
