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的行数据与列数据。与其它关系不是很大。

欢迎相互交流 学习。

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值