사칙 연산자와 산술변환
사칙 연산자
덧셈(+) 뺄셈(-) 곱셈(*) 나눗셈(/)
아래 예제코드로 학습해 보겠습니다.
class Operator4_1 {
public static void main(String[] args) {
int a = 10, b = 4;
// 덧셈
System.out.print("a + b = ");
System.out.println(a + b);
// 뺄셈
System.out.print("a - b = ");
System.out.println(a - b);
// 곱셈
System.out.print("a * b = ");
System.out.println(a * b);
// 나눗셈
// 소수점 이하는 버려진다.
System.out.print("a / b = ");
System.out.println(a / b);
// 10 / 4.0f -> 10.0f / 4.0f -> 2.5
System.out.print("a / (float)b = ");
System.out.println(a / (float)b);
}
}산술변환
연산 전에 피연산자의 타입을 일치시키는 것을 의미합니다.
1. 두 피연산자의 타입을 같게 일치시킨다.(보다 큰 타입으로 일치)
long + int -> long + long => long
float + int -> float + float => float
double + float -> double + double => double
2. 피연산자의 타입이 int 보다 작은 타입 이면 int 로 변환된다.
byte + short -> int + int => int
char + short -> int + int => int
이는 int 보다 작은 타입이 계산을 통해 쉽게 범위가 넘어갈 수 있기 때문에 오버플로우가 발생해 정확한 계산값을 가져오지 못할 수 있어서 미리 큰 범위인 int 타입으로 변환시킨 후 계산하는 것입니다.
아래 예제코드로 학습해 보겠습니다.
Last updated