일반적으로 프로그래머는 int, float, double, String과 같은 데이터 유형의 변수나 Array, List, ArrayList 등과 같은 컬렉션에 대해 작업합니다. 어떤 경우에는 프로그래머가 데이터를 추출하고 조작하기 위해 바이트 및 비트 수준에서 데이터에 훨씬 더 깊이 들어가야 합니다. Java 및 C#과 같은 언어를 사용하면 비트 수준에서 데이터를 조작할 수 있습니다. 즉, 바이트의 특정 비트에 액세스할 수 있습니다. 이번 주제에서는 Java의 비트 조작(Bit Manipulation)에 대해 알아 보겠습니다.
Java의 비트 조작은 프로그래머가 원본 데이터를 인코딩, 디코딩 또는 압축하기 위해 비트 수준에서 데이터를 추출해야 하는 데이터 압축 및 데이터 암호화 작업을 할 때 종종 필요합니다. 이 기사의 뒷부분에서 보게 될 비트 조작의 다른 많은 응용 프로그램이 있습니다.
무료 소프트웨어 개발 과정 시작
웹 개발, 프로그래밍 언어, 소프트웨어 테스팅 등
Java는 비트 수준에서 작업을 수행하기 위해 3비트 시프트와 4개의 비트 연산자를 지원합니다. 이러한 연산자는 정수 유형(int, short, long 및 byte)에 사용되어 비트 수준에서 작업을 수행할 수 있습니다.
Java Bitwise 및 Bitshift 연산자
다음은 연산자입니다:
Operator | Description |
& | Bitwise AND |
| | Bitwise OR |
~ | Bitwise Complement |
Left Shift | |
>> | Right Shift |
^ | Bitwise XOR |
>>> | Unsigned Right Shift |
Java의 비트 조작 연산자
연산자를 좀 더 자세히 살펴보겠습니다.
1. 비트 OR
이것은 2개의 피연산자를 취하고 “| “. 비트 연산자는 두 피연산자의 해당 비트를 비교합니다. 피연산자 비트 중 하나라도 1이면 출력은 1입니다. 그렇지 않으면 0이 됩니다.
예
15 = 00001111(바이너리)
27 = 00011011(바이너리)
15와 27의 비트별 OR 연산
00001111
| 00011011
________
00011111 = 31(십진수)
Java 프로그램
public class BitwiseOR { public static void main(String[] args) { int operand1 = 15, operand2 = 27, output = operand1 | operand2; System.out.println(output); } }
출력:
2.비트 AND
이 역시 2개의 피연산자를 사용하고 "&" 기호로 표시되는 비트 연산자입니다. 비트 연산자는 두 피연산자의 해당 비트를 비교합니다. 두 피연산자 비트가 모두 1이면 출력은 1입니다. 그렇지 않으면 0.
예
15 = 00001111(바이너리)
27 = 00011011(바이너리)
15와 27의 비트 AND 연산
00001111
| 00011011
________
00001011 = 11(십진수)
Java 프로그램
public class BitwiseAND { public static void main(String[] args) { int operand1 = 15, operand2 = 27, output = operand1 & operand2; System.out.println(output); } }
출력:
3. 비트별 보수
지금까지 논의한 다른 두 연산자와 달리 이 연산자는 피연산자를 하나만 사용하며 "~" 기호를 나타냅니다. 이 연산자는 피연산자의 비트를 반전시킵니다. 피연산자 비트가 0이면 이를 1로 변환하고 그 반대로 변환합니다.
예
15 = 00001111(바이너리)
15의 비트별 보수 연산
~ 00001111
________
11110000 = 240(십진수)
Java 프로그램
public class BitwiseComplement { public static void main(String[] args) { int operand= 15, output; output= ~operand; System.out.println(output); } }
출력:
임의의 숫자에 대한 2의 보수는 -(n+1)과 같습니다. 여기서 n은 2의 보수를 계산할 숫자입니다. 우리의 경우 피연산자 15의 2의 보수는 -16이며, 이는 프로그램의 출력입니다.
4. 비트별 XOR
비트별 XOR은 2개의 피연산자를 취하고 "^" 기호로 표시하는 이항 연산자입니다. 이 연산자는 두 피연산자의 해당 비트가 다른 경우 두 피연산자의 해당 비트를 비교하여 출력으로 1을 제공하고 그렇지 않으면 0을 제공합니다.
비트별 XOR 연산자는 (비트별 OR + 비트별 보수)와 동일합니다
예
15 = 00001111(바이너리)
27 = 00011011(바이너리)
15와 27의 비트별 XOR 연산
00001111
^ 00011011
________
00010100 = 20(십진수)
Java 프로그램
public class BitwiseXor { public static void main(String[] args) { int operand1= 15, operand2 = 27, output; output = operand1 ^ operand2; System.out.println(output); } }
출력:
5. 부호 있는 왼쪽 Shift
왼쪽 이동 비트 연산자는 피연산자에 지정된 특정 횟수만큼 비트 패턴을 왼쪽으로 이동합니다. 왼쪽 시프트 연산자는 "
예
123(바이너리: 01111011)
123
123
123
Java 프로그램
public class LeftShiftOperator { public static void main(String[] args) { int operand = 123; System.out.println(operand <p><strong>출력:<br> </strong></p> <p><img src="/static/imghwm/default1.png" data-src="https://img.php.cn/upload/article/000/000/000/172500478993864.jpg?x-oss-process=image/resize,p_40" class="lazy" alt="Java의 비트 조작" ></p> <h4 id="부호-있는-오른쪽-시프트">6. 부호 있는 오른쪽 시프트</h4> <p>부호 오른쪽 시프트 연산자는 왼쪽 시프트 연산자와 정확히 동일하게 작동하지만 0 비트를 추가하면 상위 위치로 시프트됩니다.</p> <p><strong>예</strong></p> <p>123(바이너리: 01111011)<br> 123>> 1은 61로 평가됩니다(이진수: 00111101)<br> 123>> 2는 30으로 평가됩니다(이진수: 00011110)<br> 123>> 3은 15로 평가됩니다. (바이너리: 00001111)</p> <p><strong>Java 프로그램</strong></p> <pre class="brush:php;toolbar:false">public class RightShiftOperator { public static void main(String[] args) { int operand = 123; System.out.println(operand >> 1); System.out.println(operand >> 2); System.out.println(operand >> 3); } }
출력:
7. 부호 없는 오른쪽 Shift
오른쪽 시프트 연산자는 피연산자에 지정된 특정 비트 수만큼 0을 가장 왼쪽 위치로 이동합니다.
Java 프로그램
public class UnSignedRightShiftOperator { public static void main(String[] args) { int operand = 123; System.out.println(operand >>> 1); System.out.println(operand >>> 2); System.out.println(operand >>> 3); } }
출력:
결론 – Java의 비트 조작
이제 기사가 끝났으니 이번 기사에서 논의한 핵심 사항을 요약하여 마무리하겠습니다. 우리는 비트 조작이 무엇인지, 그리고 다양한 사용 사례를 살펴보았습니다. 또한 다양한 유형의 비트 연산자(비트 AND, 비트 OR, 비트 보수 및 비트 XOR)와 비트 시프트 연산자(부호 있는 왼쪽 시프트 연산자, 부호 있는 오른쪽 시프트 연산자 및 부호 없는 오른쪽 시프트 연산자)를 예제와 샘플과 함께 배웠습니다. 개별 연산자를 설명하는 Java 프로그램
위 내용은 Java의 비트 조작의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

이 기사에서는 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 및 Gradle을 사용하여 접근 방식과 최적화 전략을 비교합니다.

이 기사에서는 Maven 및 Gradle과 같은 도구를 사용하여 적절한 버전 및 종속성 관리로 사용자 정의 Java 라이브러리 (JAR Files)를 작성하고 사용하는 것에 대해 설명합니다.

이 기사는 카페인 및 구아바 캐시를 사용하여 자바에서 다단계 캐싱을 구현하여 응용 프로그램 성능을 향상시키는 것에 대해 설명합니다. 구성 및 퇴거 정책 관리 Best Pra와 함께 설정, 통합 및 성능 이점을 다룹니다.

이 기사는 캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA를 사용하는 것에 대해 설명합니다. 잠재적 인 함정을 강조하면서 성능을 최적화하기위한 설정, 엔티티 매핑 및 모범 사례를 다룹니다. [159 문자]

Java의 클래스 로딩에는 부트 스트랩, 확장 및 응용 프로그램 클래스 로더가있는 계층 적 시스템을 사용하여 클래스로드, 링크 및 초기화 클래스가 포함됩니다. 학부모 위임 모델은 핵심 클래스가 먼저로드되어 사용자 정의 클래스 LOA에 영향을 미치도록합니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

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

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

안전한 시험 브라우저
안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.
