switch处理四则运算符最直接,Java 7+支持String类型,需注意break防穿透、除零检查、统一用nextDouble()避免换行残留、操作数用double保精度、输入前用hasNextDouble()校验。

用 switch 处理四则运算符最直接
用户输入的运算符(+、-、*、/)本质是字符或字符串,if-else if 链能用,但可读性和维护性差。Java 7+ 支持对 String 的 switch,比逐个 equals() 判断更干净。
注意点:
-
switch中每个case必须有break,漏写会导致“穿透”,比如输入"+"却执行了加法和减法两段逻辑 - 除零必须提前检查,
switch本身不捕获ArithmeticException,得在case "/"里显式判断b == 0 - 如果用
char接收运算符(如next().charAt(0)),switch可直接匹配case '+',无需引号包裹字符串
用 Scanner 读数字时小心输入流残留
典型错误:先用 nextLine() 读运算符,再用 nextInt() 读数字,结果第二组数字读不进——因为 nextInt() 不消费换行符,下一次 nextLine() 立刻返回空字符串。
稳妥做法:
立即学习“Java免费学习笔记(深入)”;
- 统一用
nextDouble()或nextFloat()读操作数,它们自动跳过空白符(包括换行) - 如果坚持用
nextInt(),后面紧跟一句scanner.nextLine()消耗掉残留换行 - 避免混用
nextLine()和nextXXX(),尤其在循环中反复读取时,残留问题会放大
处理除法结果精度用 double 而非 int
整数除法(int / int)直接截断小数,比如 5 / 2 得 2,不是 2.5。计算器预期输出应保留小数,所以操作数类型至少有一个是浮点型。
实操建议:
- 声明变量用
double a, b;,再调scanner.nextDouble(),后续所有运算自然按浮点规则进行 - 不要写
(double)(a / b)—— 此时除法已按整数完成,再转double也挽不回精度损失 - 如果输入是整数但想显示 .0(如
4.0),可用System.out.printf("%.1f", result)统一格式化,避免4.0和4.5输出格式不一致
import java.util.Scanner;
<p>public class SimpleCalculator {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.print("请输入第一个数字: ");
double a = scanner.nextDouble();
System.out.print("请输入运算符 (+, -, *, /): ");
String op = scanner.next();
System.out.print("请输入第二个数字: ");
double b = scanner.nextDouble();</p><pre class='brush:java;toolbar:false;'> double result = 0;
boolean valid = true;
switch (op) {
case "+":
result = a + b;
break;
case "-":
result = a - b;
break;
case "*":
result = a * b;
break;
case "/":
if (b == 0) {
System.out.println("错误:除数不能为零");
valid = false;
} else {
result = a / b;
}
break;
default:
System.out.println("错误:不支持的运算符 '" + op + "'");
valid = false;
}
if (valid) {
System.out.printf("结果: %.2f\n", result);
}
scanner.close();
}}
真正容易被忽略的是输入校验粒度——Scanner 遇到非数字输入会抛 InputMismatchException,而上面代码没包 try-catch。实际部署时,哪怕只是练习,也该用 hasNextDouble() 预检再读,否则一次输错就中断整个程序。










