给Java类填入默认值

项目背景:录接口数据。当时的原材料是Java源代码,产出是RAP文档。在可预见的未来,Controller代码中接收一个VO,返回一个VO。OK,就是这两个对象,我先把它们序列化成JSON,然后在RAP中导入。

过程中发现需要填各种数据类型的默认值。我们都知道,任何复杂的对象都是由基本数据类型构成的。所以,这个程序理想状态比较简单,只需要将VO的所有域中是基本数据类型的直接填值,其它类型递归处理。

但是,问题来了。数据集合类型中的域不是那么简单,size不能随意填,另外范性也需要特殊关照。所以,数据集合类型也扩充进来。

接着,问题又来了。我的小伙伴写的个别VO没那么单纯。所以也成了我的特殊关照类型。我当时的内心是这样的:

console.log('照这样下去,不会马上就……');

 于是,我想到了开闭原则:只要对扩展是开放的就好了。

源代码地址

    private List integerList;

    public static void main(String[] args) throws NoSuchFieldException {
        IntDefaultValueGenerator intDefaultValueGenerator = new IntDefaultValueGenerator();

        ListDefaultValueGenerator listDefaultValueGenerator = new ListDefaultValueGenerator();
        listDefaultValueGenerator.add(intDefaultValueGenerator);

        ChainedDefaultValueGenerator4Context root = new ChainedDefaultValueGenerator4Context();
        root.add(listDefaultValueGenerator);
        root.add(intDefaultValueGenerator);

        Field integerList = Main.class.getDeclaredField("integerList");
        root.set(new Context(integerList.getType(), integerList.getGenericType()));

        System.out.println(root.generate());
    }

 
简单的描述这份代码: intDefaultValueGenerator 是一个基本处理单元, listDefaultValueGenerator 有着双重身份,对于 intDefaultValueGenerator 来说它是一个容器,对于 root 来说它也是一个基本处理单元。那么程序的输出是这样的。

GeneratedValue{suc=true, value=[1]}

Process finished with exit code 0

猜你喜欢

转载自c-shadow.iteye.com/blog/2285357