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() 立刻返回空字符串。
稳妥做法:
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 也挽不回精度损失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()预检再读,否则一次输错就中断整个程序。