목표
- 자바가 제공하는 다양한 연산자를 학습하세요
학습할것
- 산술 연산자
- 비트 연산자
- 관계 연산자
- 논리 연산자
- instanceof
- assignment(=) operator
- 화살표(->) 연산자
- 3항 연산자
- 연산자 우선 순위
- (optional) Java 13. switch 연산자
산술 연산자
-
산술연산자는 사칙연산자 ( + , - , * , / ) 4개와 나머지 연산자 ( % ) 로 이루어져 있다.
-
사칙 연산자
-
피 연산자가 정수 일 경우 0 으로 나눌수 없다.
-
피 연산자가 같을 경우 결과는 피연산자와 같고
-
피 연산자가 다를 경우 ( 정수 + 실수 ) 조합일 때 결과는 실수가 된다.
-
피 연산자가 다를 경우에는 좀더 범위가 넓은쪽을 결과의 타입으로 쓴다.
-
연산자 결과의 최소 타입은 int형이다.
byte a = 1; byte b = 1; byte c = a+b; // 에러발생 provided는 int형 인데 byte에 담으려 했기 때문 byte c = (byte)(a+b); // 명시적 형변환할 경우 에러안남- byte+byte로 더해서 byte에 담으려 하면 에러가 난다.
- 결과는 int로 나오는데 int ( 4byte)보다 더작은 byte에 담으려 했기 때문
- 이때는 명시적으로 형변환을 시켜줘야 한다.
- 하지만 큰 타입에서 작은 타입으로 변환해서 데이터를 넣을 경우
- 값이 작은 타입의 데이터 범위를 넘을 경우 데이터 손실이 일어난다.
- byte+byte로 더해서 byte에 담으려 하면 에러가 난다.
- 같은 타입 피연산자의 연산결과 합이 타입의 허용 값을 넘어서 결과가 나온다면
- 더 높은값을 담을수 있는 타입에 저장할 때 이 타입의 형태로 저장되는게 아닌 피연산자 타입의 연산결과의 합이 담긴다.
- 그리고 연산 중 오버플로우가 일어난다면
- 상위 타입에 저장한다고 해도 이미 오버플로우가 일어나서 오버플로우가 일어나기 전까지의 값만 저장가능하다.
-
-
문자열 연산
char a = 'a'; char b = 'b'; char c = a+b; // 결과값은 Ã String a = "a"; String b = "b"; String c = a+b; final char a= 'a'; final char b = 'b'; char ccc = a+b; // 에러 안남
-
char의 문자열 연산은 해당문자의 유니코드 ( 정수 ) 로 바뀌어 저장되므로 정수간의 연산이된다.
-
문자열 자체가 더해지는 것이 아닌 유니코드가 더해져서 char에 변수에 담는것이다.
-
재밌게도 스트링은 따로 형변환을 안해도 되고 그자체로 더해진다.
- 그 이유는 스트링은 리터럴이기 때문이다.
- 리터럴 끼리의 합은 형변환을 안해도 된다.
- 문자열 끼리만이 아닌 정수와 실수도 가능하다.
-
리터럴 연산
- 리터럴 연산은 컴파일시 컴파일러가 먼저 계산하고 리터럴간의 연산을 먼저 실행시킨다.
- 그래서 형변환을 안해도 연산이 되는것이다.
- 만약 리터럴이 아닐경우 도중에 값이 바뀔 위험이 있기에 컴파일러가 미리 연산을 하지 못한다 그래서 형변환이 필요한것이다.
-
나머지 연산자
- 왼쪽의 피 연산자를 오른쪽의 피연산자로 나누고 난 나머지 값을 결과로 리턴하는 연산자.
- 나눗셈처럼 나누는 수 ( 오른쪽 피 연산자) 를 0으로 사용할수 없다.
비트 연산자
-
피연산자를 비트단위로 논리 연산한다.
-
피연산자를 이진수로 표현할 경우의 각 자리를 규칙에따라 연산하고 피연산자로 실수는 허용하지 않는다. 정수만 가능
-
연산 규칙
- | ( OR 연산자 )
- 피연산자 중 한쪽의 값이 1이면 1로 값을 리턴한다 그 이외에는 0으로 리턴
- & ( AND 연산자 )
- 피연산자 양쪽이 모두 1이어야만 1로 값으로 리턴한다. 그이외에는 0으로 리턴
- ^ ( XOR 연산자 )
- 피연산자의 값이 서로 다를때만 1로 값을 리턴한다. 같을때는 0을 리턴한다.
- | ( OR 연산자 )
-
쉬프트 연산자 << >>
- 피연산자의 각 자리 ( 2진수로 표현했을 때)를
- 오른쪽 >> 또는 왼쪽 << 으로 이동한다고 해서 쉬프트 연산자 라고 불린다.
- 예를 들어 " 8 << 2 " 는 왼쪽 피연산자인 10진수의 8의 2진수를 왼쪽으로 2자리 이동한다.
-
비트전환 연산자 ~
- 피연산자를 2진수로 표현했을때 0은 1로 , 1은 0으로 바꾼다.
관계 연산자
- 두 연산자를 비교하는데 사용되는 연산자다.
- 주로 조건문 과 반복문의 조건식에 사용된다.
- 결과는 오직 true, false 단 두개뿐이다.
대소비교 연산자
-
두 연산자의 값의 크기를 비교하는 연산자
-
참 일 경우 true , 거짓이면 false를 리턴한다.
-
boolean형을 제외한 나머지 자료형에는 사용가능하나 참조형에는 사용할수 없다.
-
4가지 종류가 존재한다.
-
- 좌변이 크면 ture 아니면 false
- <
- 좌변이 작으면 true 아니면 false
-
=
- 좌변이 크거나 같으면 true 아니면 false
- <=
- 좌변이 작거나 같으면 true 아니면 false
-
등가비교 연산자
-
두 피연산자의 값이 같은지 또는 다른지를 비교하는 연산자
-
대소비교 연산자와 다르게 기본형 , 참조형 , 모든 자료형에 사용 가능하다.
-
기본형의 등가비교일 경우 저장되어있는 값이 같은지를 알수 있고
-
참조형의 등가비교일 경우 저장되어있는 객체의 주소값을 비교한다.
-
2가지 종류가 존재
- ==
- 두 값이 같으면 ture 아니면 false
- !=
- 두 값이 다르면 true 아니면 false
- ==
문자열의 비교
- String으로 문자열을 비교할 경우에는 == 대신 equals를 사용 해야 한다.
- ==로 비교하는 것은 참조주소를 비교한다는 것이기 때문에 만약 문자열이 같더라도
- 참조주소가 다르면 다른것으로 간주하기 때문이다.
- equals를 사용하면 문자열을 비교하기 때문에 문자열이 같으면 true를 반환한다.
논리 연산자
- 2가지 조건으로 결합하여 참과 거짓을 구분한다.
- && 와 ||
boolean a = true; boolean b = false; (a && a) // true (a || a) // true (a && b) // false (a || b) // true (b && b) // false (b || b) // false
- 2가지 조건
- && ( AND 결합 )
- 피연산자 양쪽 모두 true 이어야 true를 리턴한다.
- || ( OR 결합 )
- 피연산자 중 한쪽 만 true면 true를 리턴 한다.
- && ( AND 결합 )
논리 부정 연산자
- 피연산자가 true면 false로 false면 true로 결과를 바꿔서 리턴한다.
boolean a = true; boolean b = false; !a // false; !b // true;
instance of 연산자
- 참조변수가 참조하고 있는 인스턴스의 실제 타입을 확인하는 연산자.
- instanceOf 가 true 란 것은 그 타입일수도 있고 그 타입으로 형변환이 가능하다는 것이다.
void test (Car c) { if (c instanceOf SportsCar) { SportsCar sc = (SportsCar)c; } }
- 위와 같이 사용할 경우 test 메소드의 Car c의 타입을 정확히 알수가 없다.
- 진짜 car인지 아니면 car의 자손 클래스인지 정확히 알수가 없다.
- 그렇기 떄문에 체크해서 사용한다.
assignment(=) operator
-
대입 연산자
- 변수와 같은 저장공간에 값 또는 수식의 연산결과를 저장하는데 사용
- 오른쪽 피연산자의 값을 왼쪽 피연산자에 저장한다.
- 대입 연산자의 왼쪽 피연산자를 lvalue ( left value ) 라고 하며
- 오른쪽을 rvalue ( right value ) 라고 한다.
-
복합 대입연산자
- 다른 연산자와 결합하여 op= 와 같은 방식으로 사용가능하다.
화살표 연산자
- lambda를 표현식을 작성하기 위한 연산자다.
1. Interface k = new Interface() { @Override public void main() { } }; 2. Koy k = () -> { };
- 위와 같이 인터페이스의 메소드가 1개일 경우 아래와같이 익명함수를 간단하게 람다식으로 변경할수 있다.
3항 연산자
- 피연산자를 3개를 사용하는 연산자
- 조건식과 결과 결과 로 이루어져 있으며 결과에 다시 3항연산자가 들어갈수도 있다.
int a = 1; int b = 2; int c = 3; boolean d = a < b ? true : false boolean d = a < b ? a < c ? true : false : false
연산자 우선순위
- 식에 사용된 연산자가 둘 이상일 경우 연산자 우선순위에 의해 순서가 결정된다.
- 곱셈과 나눗셈은 덧셈과 뺼셈보다 우선순위가 높다. ( 기초수학 )
x << 2 + 1 data & 0xFF == 0 x < 1 || x > 3 && x < 5
- << 연산자는 덧셈 연산자보다 우선순위가 낮다.
- & 연산자는 == 연산자보다 우선순위가 낮다.
- &와 && 연산자는 |과 || 보다 우선순위가 높다.
- and 와 or을 같이사용하는 경우에는 괄호를 사용해 우선순위를 명확하게 하는것이 좋다.
x + 3 > y - 2 x > 3 && x - 2 result = x + y * 3
-
비교연산자는 산술 연산자보다 우선순위가 낮다
- && 연산자는 비교 연산자보다 순위가 낮다.
- 대입연산자는 연산자중에서 우선순위가 제일 낮다.
우선순위 결론
-
산술 > 비교 > 논리 > 대입 의 순위이며
-
대입은 제일 마지막에 수행된다.
-
단항 > 이항 > 삼항
-
단항 연산자의 우선순위가 이항 연산자보다 높다.
-
단항 연산자와 대입연산자를 제외한 모든 연산의 진행방향은 왼쪽에서 오른쪽이다.
Java 13 Switch Operator
-
preview 기능이므로 —enable-preview 옵션을 줘야 사용할수 있다.
-
: 대신 → 를 사용할 수 있다.
-
switch가 expression으로 사용될 수 있다.
- 타입을 지정하고 변수를 할당할수 있게 되었다.
-
yeild 키워드가 추가 되었다.
- return과 같이 사용가능.
switch (name) { case "KKK" -> System.out.println("이름이 KKK"); case "DDD" -> System.out.println("이름이 DDD"); } String result = switch (name) { case "KKK" -> "nameKKK"; case "DDD" -> "nameDDD"; }; String result = switch (name) { case "KKK" -> "nameKKK"; case "DDD" -> "nameDDD"; default -> { String a = "newname" yield a; } };
출처
https://johngrib.github.io/wiki/jdk13/#switch-expressions-preview
자바의정석
'백선생님 온라인스터디' 카테고리의 다른 글
6주차 상속 (0) | 2021.01.10 |
---|---|
4주차 - 제어문 (0) | 2021.01.09 |
연산자 (0) | 2020.11.28 |
스터디 2주차 - 자바 데이터타입, 변수 그리고 배열 (0) | 2020.11.21 |
스터디 1주차 - JVM (0) | 2020.11.15 |