今天上课,老师出了一个据说是面试题目的东东:编写一个虚数类(a+bi),并提供相加和相减的方法。
题目一出来,众皆不屑,这是什么题目,顺手拈来。
public class imaginaryNumber{
private int a ; //实数部分
private int b ; //虚数部分
public imaginaryNumber(int a,int b){
this.a = a;
this.b = b;
}
public String toString(){
return new String(this.a+"+"+this.b+"i");
}
}
这是类的数据结构,很简单。然后是相加的方法。
首先是一个同学这么写的:
public void add(imaginaryNumber o2){
this.a += o2.a;
this.b += o2.b;
}
老师说,答案刚及格。为什么? 基本功能实现了,一个很简单的破绽:不支持连加,当几个数相加时,很麻烦。
皆颔首同意,又一人改之:
public imaginaryNumber add(imaginaryNumber o2){
return new imaginaryNumber(this.a+o2.a , this.b+o2.b);
}
想:这次总可以了吧
老师说跟上面的是一个分数。提问:为什么?
想半天。
老师答:每加一次,都要创建一个imaginaryNumber对象,浪费内存
想:靠,这样的啊。平时还真没想过
最后老师给了一个算好的答案,将上面的2种优势结合起来:
public imaginaryNumber add(imaginaryNumber o2){
this.a += o2.a;
this.b += o2.b;
return this;
}
答案虽不是最好,肯定有更好的答案,但这个例子说明了一个问题
我们平时每一下敲键盘的时候,是否想清楚了?是否是最好的方式?是否考虑到了整个程序的性能要求?
简而言之,我们是否认真对待过我们做的东西?
例子虽小,感触颇深,回来就记下来了。