프로그래밍 언어/자바
연산자2
dks_a
2022. 5. 1. 10:33
public class 연산자2 {
public static void main(String[] args) {
// A) 산술 쉬프트 연산자 : 부호비트는 고정 (= 부호 변화가 없다)
// Left 시프트는 그 결과 숫자가 커진다, 2의 n제곱
// System.out.println(3 << 1); //6, 2배//0011(3의 2진수)
// System.out.println(-3 << 1); //-6, 2배
// System.out.println(3 << 2); //12, 4배 -> 1100이 된다는 소리
// System.out.println(-3 << 2); //-12, 4배
for(int i =0; i<4; i++) {
System.out.printf("3 << %d = %32s, %d\n", i, Integer.toBinaryString(3 << i), (3 << i));
}
System.out.println();
for(int i =0; i<4; i++) {
System.out.printf("-3 << %d = %32s, %d\n", i, Integer.toBinaryString(-3 << i), (-3 << i));
}
System.out.println();
//right 시프트는 그 결과 숫자가 작아짐, 2의 1/n제곱
// System.out.println(5 >> 1); //2, floor(5/2), 좌측의 정수값 //0101(5의 2진수)
// System.out.println(-5 >> 1); //-3, floor(-5/2), 좌측의 정수값
// System.out.println(5 >> 2); //1, floor(5/4)
// System.out.println(-5 >> 2); //-2, floor(-5/4)
for(int i =0; i<4; i++) {
System.out.printf("5 >> %d = %32s, %d\n", i, Integer.toBinaryString(5 >> i), (5 >> i));
}
System.out.println();
for(int i =0; i<4; i++) {
System.out.printf("-5 >> %d = %32s, %d\n", i, Integer.toBinaryString(-5 >> i), (-5 >> i));
}
System.out.println();
//B) 논리 쉬프트 연산자 : 부호비트도 이동 (*음수는 경우에 따라 양수로 바뀔 수도 있음)
// 용도 : (a >>> n) & "...0001"과 같이 사용하면 a의 특정 n번째 비트값을 추출할 수 있음(비트단위로 저장)
//논리 쉬프트는 >>> 만 존재 : 양수일 땐 >> 와 동일
// System.out.printf("%32s >>> 1 = %32s, %d\n", Integer.toBinaryString(5),
// Integer.toBinaryString(5 >>> 1), 5 >>> 1);
// ...0010, 10진수로 2
//101 >>> 1 = 10, 2
// System.out.printf("%32s >>> 31 = %32s, %d\n", Integer.toBinaryString(-5),
// Integer.toBinaryString(-5 >>> 31), -5 >>> 31);
// ...0001, 10진수로 1, 부호변동
//'1'1111111111111111111111111111011 >>> 31 = 1, 1
for(int i =0; i<4; i++) {
System.out.printf("5 >>> %d = %32s, %d\n", i, Integer.toBinaryString(5 >>> i), (5 >>> i));
}
System.out.println();
for(int i =0; i<4; i++) {
System.out.printf("-5 >>> %d = %32s, %d\n", i, Integer.toBinaryString(-5 >>> i), (-5 >>> i));
}
System.out.println();
}
}