java深入浅出设计模式----简单的工厂模式(一)----初学者容易犯的错误(一)

package aa;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

import com.sun.xml.internal.txw2.IllegalAnnotationException;

/**
 * 我的QQ : 2622596982
 * 
 * 邮箱: android_lzd@163.com
 * 
 * QQ 交流群 : 277599214
 * 
 * tips : 欢饮各位朋友多多提意见,小弟不胜感激
 * 
 * 
 * 
 */
public class Calculator {
	private static String result;
	private static int res;

	/*
	 * 用户 :输入第一个数
	 * 
	 * 用户:输入计算符号
	 * 
	 * 用户: 输入第二个数
	 * 
	 * 系统:运算出结果
	 */
	public static void main(String[] args) {
		try {
			// 输入第一个数
			System.out.println("请输入第一个数:");
			BufferedReader reader = new BufferedReader(new InputStreamReader(
					System.in));
			String num1 = reader.readLine();

			// 输入运算符
			System.out.println("请输入运算符号:+、-、*、/");
			BufferedReader reader1 = new BufferedReader(new InputStreamReader(
					System.in)); // 频繁的 new该对象
			String symbol = reader1.readLine();

			// 输入第二个数
			System.out.println("请输入第二个数:");
			BufferedReader reader2 = new BufferedReader(new InputStreamReader(
					System.in)); // 频繁的 new该对象
			String num2 = reader2.readLine();

			if ("+" == symbol) { // 错误的使用 “==”
				res = Integer.valueOf(num1) + Integer.valueOf(num2);
				result = String.valueOf(res);
			}

			if ("-" == (symbol)) { // 错误的使用 “==” // 频繁的判断,相当于计算机多了一次无用功
				res = Integer.valueOf(num1) - Integer.valueOf(num2);
				result = String.valueOf(res);
			}

			if ("*" == (symbol)) { // 错误的使用 “==” // 频繁的判断,相当于计算机多了一次无用功
				res = Integer.valueOf(num1) * Integer.valueOf(num2);
				result = String.valueOf(res);
			}

			if ("/" == (symbol)) { // 错误的使用 “==” // 频繁的判断,相当于计算机多了一次无用功
				res = Integer.valueOf(num1) / Integer.valueOf(num2);	// 除数为 0 时怎么办?
				result = String.valueOf(res);
			}

			System.out.println(res); // 结果肯定是 0
			System.out.println(result); // 结果肯定是 null

		} catch (IOException e) {
			new IllegalAnnotationException("出错啦~");
		}
	}
}


优化后:
package aa;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

import com.sun.xml.internal.txw2.IllegalAnnotationException;

/**
 * 我的QQ : 2622596982
 * 
 * 邮箱: android_lzd@163.com
 * 
 * QQ 交流群 : 277599214
 * 
 * tips : 欢饮各位朋友多多提意见,小弟不胜感激
 * 
 * 
 * 
 */
public class Calculator1 {
	private static String result;
	private static int res;

	/*
	 * 用户 :输入第一个数
	 * 
	 * 用户:输入计算符号
	 * 
	 * 用户: 输入第二个数
	 * 
	 * 系统:运算出结果
	 */
	public static void main(String[] args) {
		BufferedReader reader = null;
		try {
			// 输入第一个数
			System.out.println("请输入第一个数:");
			reader = new BufferedReader(new InputStreamReader(System.in));
			String num1 = reader.readLine();

			// 输入运算符
			System.out.println("请输入运算符号:+、-、*、/");
			String symbol = reader.readLine();

			// 输入第二个数
			System.out.println("请输入第二个数:");
			String num2 = reader.readLine();

			switch (symbol) {
			case "+":
				res = Integer.valueOf(num1) + Integer.valueOf(num2);
				break;
			case "-":
				res = Integer.valueOf(num1) - Integer.valueOf(num2);
				break;
			case "*":
				res = Integer.valueOf(num1) * Integer.valueOf(num2);
				break;
			case "/":
				if (!num2.equals("0")) {
					res = Integer.valueOf(num1) / Integer.valueOf(num2);
				} else {
					System.out.println("除数不能为0");
				}
				break;

			default:
				break;
			}
			// System.out.println(res);
			result = String.valueOf(res);
			System.out.print("计算结果是:");
			if (symbol.equals("/") && num2.equals("0")) {
				System.out.println("请重新计算");
			} else {
				System.out.println(result);
			}
		} catch (IOException e) {
			new IllegalAnnotationException("出错啦~");
		}
	}
}

这样逻辑计算是满足需求了,可是这样的代码还有什么问题吗?


知道的可以提出你们的看法







  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值