# Java Math Operators | Developer.com

Java helps your whole normal arithmetic operators for performing primary math on Java variables and/or literals. This programming tutorial will take a more in-depth have a look at each Java’s binary and unary math operators, ensuing knowledge varieties, in addition to operator priority guidelines.

## Binary Arithmetic Operators

Java’s binary arithmetic operators are employed to carry out operations that contain two numbers. Java helps a complete of 5 binary arithmetic operators, that are relevant to all floating-point and integer numbers. They’re:

• (subtraction)
• * (multiplication)
• / (division)
• % (modulo)

Until you skipped grade 3 math, you’re most likely conversant in the primary 4 arithmetic operators. That final one – modulo – is used extra not often than the others; it computes the rest of dividing one quantity by one other. Therefore, if we have been to divide 3 by 2, the rest can be 1. In code that might be expressed as `int the rest = 3 % 2`.

Here’s a code instance displaying a category that exhibits using the above operators on quite a lot of integer and double quantity mixtures:

```public class BinaryOperatorsExample {

public static void predominant(String[] args) {

//declare just a few numbers
int int1 = 3;
int int2 = 5;
double double1 = 9.99;
double double2 = 6.66;
System.out.println("Variable values:");
System.out.println("    int1 = " + int1);
System.out.println("    int2 = " + int2);
System.out.println("    double1 = " + double1);
System.out.println("    double2 = " + double2);

//including numbers
System.out.println("    int1 + int2 = " + (int1 + int2));
System.out.println("    double1 + double2 = " + (double1 + double2));

//subtracting numbers
System.out.println("Subtraction:");
System.out.println("    int1 - int2 = " + (int1 - int2));
System.out.println("    double1 - double2 = " + (double1 - double2));

//multiplying numbers
System.out.println("Multiplication:");
System.out.println("    int1 * int2 = " + (int1 * int2));
System.out.println("    double1 * double2 = " + (double1 * double2));

//dividing numbers
System.out.println("Division:");
System.out.println("    int1 / int2 = " + (int1 / int2));
System.out.println("    double1 / double2 = " + (double1 / double2));

//computing the rest after division
System.out.println("Remainders:");
System.out.println("    int1 % int2 = " + (int1 % int2));
System.out.println("    double1 % double2 = " + (double1 % double2));

//mixing varieties
System.out.println("Mixing varieties:");
System.out.println("    int2 + double2 = " + (int2 + double2));
System.out.println("    int1 * double1 = " + (int1 * double1));
}
}
```

Compiling and executing the above program produces the next output:

```Variable values:
int1 = 3
int2 = 5
double1 = 9.99
double2 = 6.66
int1 + int2 = 8
double1 + double2 = 16.65
Subtraction:
int1 - int2 = -2
double1 - double2 = 3.33
Multiplication:
int1 * int2 = 15
double1 * double2 = 66.5334
Division:
int1 / int2 = 0
double1 / double2 = 1.5
Remainders:
int1 % int2 = 3
double1 % double2 = 3.33
Mixing varieties:
int2 + double2 = 11.66
int1 * double1 = 29.97
```

## Outcome Forms of Arithmetic Operations in Java

Mixing two totally different knowledge varieties inside a single arithmetic operation will trigger one of many operands to be transformed to the opposite’s sort earlier than the operation happens. The frequent sort is then maintained within the end result. For instance, mixing an integer with a floating-point quantity produces a floating level end result because the integer is implicitly transformed to a floating-point sort. Here’s a abstract of the information sort returned by the arithmetic operators, primarily based on the information sort of the operands:

• int: Neither operand is a float or a double (integer arithmetic); neither operand is an extended.
• lengthy: Neither operand is a float or a double (integer arithmetic); a minimum of one operand is an extended.
• double: A minimum of one operand is a double.
• float: A minimum of one operand is a float; neither operand is a double.

## Expression Analysis Guidelines in Java

It’s possible you’ll be stunned to study that what we builders consider as operator priority truly pertains to a few totally different guidelines! They’re operator priority, operator associativity, and order of operand analysis. Java depends on all three guidelines for evaluating expressions, so let’s have a look at every of them.

### Operator Priority in Java

As chances are you’ll already bear in mind, operator priority governs how operands are grouped with operators. Almost about the arithmetic operators, *, ?, and % have the next priority than + and . Therefore, 1 + 2 * 3 is handled as 1 + (2 * 3), whereas 1 * 2 + 3 is handled as (1 * 2) + 3. Builders can use parentheses to override the built-in operator priority guidelines; for instance: (1 + 2) * 3.

### Java Operator Associativity

Since *, ?, and % all share equal priority, as do + and , this begs the query: what occurs when an expression has two operators with the identical priority? In that occasion, the operators and operands are grouped in line with their associativity. The Java arithmetic operators are all left-to-right associative, in order that 99 / 2 / 4 is handled as (99 / 2) / 4. Once more, programmers can use parentheses to override the default operator associativity guidelines.

### Java Order of Operand Analysis

Associativity and priority decide by which order Java teams operands and operators, but it surely doesn’t decide by which order the operands are evaluated. Fortunately, in Java, this one is a no brainer, because the operands of an operator are at all times evaluated left-to-right. The order of operand analysis rule comes into play when perform argument lists and subexpressions are concerned. As an illustration, within the expression a() + b() * c(d(), e()), the subexpressions are evaluated within the order a(), b(), d(), e(), and c().

## Unary Arithmetic Operators in Java

The + and operators have the excellence of working in each a binary and unary context. Right here is how every operator capabilities in unary mode in Java:

• +: eg, +op, represents the operand as a optimistic worth
• : eg, -op, represents the operand as a destructive worth

As seen within the following instance, making use of the + operator on a optimistic quantity, or making use of the operator on a destructive quantity, has no impact, which is helpful should you have no idea a quantity’s signal beforehand:

```int a = 24;
int b = -24;

System.out.println(+a); // 24
System.out.println(+b); // -24
System.out.println(-a); // -24
System.out.println(-b); // 24
```

Java additionally helps the shortcut arithmetic operators ++ and , which increment and decrement their operands by 1 respectively. These unary operators could be positioned earlier than (prefix) or after (postfix) their operands, thereby affecting analysis order. The prefix model, ++op/–op, evaluates to the worth of the operand after the increment/decrement operation, whereas the postfix model, op++/op–, evaluates to the worth of the operand earlier than the increment/decrement operation.

Programmers will typically see the increment/decrement operators in for loops, akin to these, which kind an array of integers:

```public class IncrementorDecrementorSortExample {
public static void predominant(String[] args) {
remaining int[] arrayOfInts =
{ 9, 65, 3, 400, 12, 1024, 2000, 33, 733 };

for (int i = arrayOfInts.size; --i >= 0; ) {
for (int j = 0; j < i; j++) {
if (arrayOfInts[j] > arrayOfInts[j+1]) {
int temp = arrayOfInts[j];
arrayOfInts[j] = arrayOfInts[j+1];
arrayOfInts[j+1] = temp;
}
}
}

for (int i = 0; i < arrayOfInts.size; i++) {
System.out.print(arrayOfInts[i] + " ");
}
}
}
// Outputs: 3 9 12 33 65 400 733 1024 2000
```

## Closing Ideas on Java Math Operators

On this programming tutorial, we discovered about Java’s binary and unary arithmetic operators. These are greatest suited to performing primary math operations on Java variables. For extra complicated calculations, Java additionally supplies the Java Math class, which incorporates a variety of strategies akin to min(), max(), spherical(), random(), and plenty of others.