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;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();
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()预检再读,否则一次输错就中断整个程序。










