EXCEL导出引发的思考(下)
要解决上篇的问题,首先要确定反射获取的字段是否存在顺序!通过程序我们知道反射获取字段返回的是FIELD类型的数组,由于数组是有顺序的,我们只要确定FIELD数据的存储顺序就好了。实验代码如下:
1>bean的代码
package reflection;
public class User {
private String name;
private String password;
private String id;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
}
2>测试代码
package reflection;
import java.lang.reflect.Field;
public class Reflection {
public static void main(String[] args) throws ClassNotFoundException {
Class clazz = Class.forName("reflection.User");
Field[] feilds = clazz.getDeclaredFields();
}
}
测试结果如下:
从图中可以看,反射字段的顺序与类的字段顺序一致的。那么我们可以得出结论,如果EXCEL头描述的字段顺序与EXCEL实体信息字段的顺序一致,就不会发生数据错乱。
一个程序的好坏,不应该只看可扩展性,还有一个重要的标准:复杂度。举个例子:如果一个程序可扩展性良好,但是复杂度成几何平方或者幂次级的话,无疑是一个很糟糕的程序。我们再次探索一下上篇程序的复杂度。
假设:要导出的sheet页是N,数据为Y + 1行M列,复杂度如下:那么上述程序的复杂度
设置头信息的复杂度为O(N * (M *1 ));
设置实体数据的复杂度为O(N ( M * Y) );
设置EXCEL的最优复杂度为O(1),最坏复杂度为O(N *(M * (Y+ 1)))
总的复杂度应该为O(n *( M * (2Y + 2))),即 O(MY)。从程序的复杂度可以看出来,程序的执行取决于EXCEL的行数据与列数据。与其它关系不是很大。
欢迎相互交流 学习。