【@JsonSubTypes 使用示例】

@JsonSubTypes注解是Jackson库中的一个注解,用于指定多态类型的子类序列化和反序列化时的类型标识。

例如,我们有一个抽象类Animal,它有两个子类Dog和Cat。我们希望在序列化和反序列化过程中能够正确地识别出具体的子类类型。

首先,我们需要在抽象类Animal上使用@JsonTypeInfo注解,指定使用类型标识字段来识别具体的子类类型。同时,还需要使用@JsonSubTypes注解,指定所有可能的子类类型。

java 复制代码
@JsonTypeInfo(use = JsonTypeInfo.Id.NAME, property = "type")
@JsonSubTypes({
    @JsonSubTypes.Type(value = Dog.class, name = "dog"),
    @JsonSubTypes.Type(value = Cat.class, name = "cat")
})
public abstract class Animal {
    private String name;

    public Animal(String name) {
        this.name = name;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
}

接下来,我们可以定义Dog和Cat两个具体的子类,它们需要继承自Animal类。

java 复制代码
public class Dog extends Animal {
    private int age;

    public Dog(String name, int age) {
        super(name);
        this.age = age;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }
}

public class Cat extends Animal {
    private String color;

    public Cat(String name, String color) {
        super(name);
        this.color = color;
    }

    public String getColor() {
        return color;
    }

    public void setColor(String color) {
        this.color = color;
    }
}

最后,我们可以使用ObjectMapper类来进行序列化和反序列化操作。

java 复制代码
public class Main {
    public static void main(String[] args) throws JsonProcessingException {
        ObjectMapper objectMapper = new ObjectMapper();

        // 序列化
        Dog dog = new Dog("旺财", 3);
        String dogJson = objectMapper.writeValueAsString(dog);
        System.out.println(dogJson); // {"type":"dog","name":"旺财","age":3}

        Cat cat = new Cat("小花", "white");
        String catJson = objectMapper.writeValueAsString(cat);
        System.out.println(catJson); // {"type":"cat","name":"小花","color":"white"}

        // 反序列化
        Animal deserializedDog = objectMapper.readValue(dogJson, Animal.class);
        if (deserializedDog instanceof Dog) {
            Dog deserializedDog1 = (Dog) deserializedDog;
            System.out.println(deserializedDog1.getAge());
        }

        Animal deserializedCat = objectMapper.readValue(catJson, Animal.class);
        if (deserializedCat instanceof Cat) {
            Cat deserializedCat1 = (Cat) deserializedCat;
            System.out.println(deserializedCat1.getColor());
        }
    }
}

以上代码中,我们首先使用ObjectMapper类将Dog对象和Cat对象序列化为JSON字符串,然后通过readValue方法将JSON字符串反序列化为Animal对象。最后,根据实际的类型进行类型转换。

在序列化过程中,@JsonTypeInfo注解将类型信息包括在JSON字符串中的"type"字段中。在反序列化过程中,根据"type"字段的值来决定具体的子类类型。@JsonSubTypes注解是Jackson库中的一个注解,用于指定多态类型的子类序列化和反序列化时的类型标识。

例如,我们有一个抽象类Animal,它有两个子类Dog和Cat。我们希望在序列化和反序列化过程中能够正确地识别出具体的子类类型。

首先,我们需要在抽象类Animal上使用@JsonTypeInfo注解,指定使用类型标识字段来识别具体的子类类型。同时,还需要使用@JsonSubTypes注解,指定所有可能的子类类型。

java 复制代码
@JsonTypeInfo(use = JsonTypeInfo.Id.NAME, property = "type")
@JsonSubTypes({
    @JsonSubTypes.Type(value = Dog.class, name = "dog"),
    @JsonSubTypes.Type(value = Cat.class, name = "cat")
})
public abstract class Animal {
    private String name;

    public Animal(String name) {
        this.name = name;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
}

接下来,我们可以定义Dog和Cat两个具体的子类,它们需要继承自Animal类。

java 复制代码
public class Dog extends Animal {
    private int age;

    public Dog(String name, int age) {
        super(name);
        this.age = age;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }
}

public class Cat extends Animal {
    private String color;

    public Cat(String name, String color) {
        super(name);
        this.color = color;
    }

    public String getColor() {
        return color;
    }

    public void setColor(String color) {
        this.color = color;
    }
}

最后,我们可以使用ObjectMapper类来进行序列化和反序列化操作。

java 复制代码
public class Main {
    public static void main(String[] args) throws JsonProcessingException {
        ObjectMapper objectMapper = new ObjectMapper();

        // 序列化
        Dog dog = new Dog("旺财", 3);
        String dogJson = objectMapper.writeValueAsString(dog);
        System.out.println(dogJson); // {"type":"dog","name":"旺财","age":3}

        Cat cat = new Cat("小花", "white");
        String catJson = objectMapper.writeValueAsString(cat);
        System.out.println(catJson); // {"type":"cat","name":"小花","color":"white"}

        // 反序列化
        Animal deserializedDog = objectMapper.readValue(dogJson, Animal.class);
        if (deserializedDog instanceof Dog) {
            Dog deserializedDog1 = (Dog) deserializedDog;
            System.out.println(deserializedDog1.getAge());
        }

        Animal deserializedCat = objectMapper.readValue(catJson, Animal.class);
        if (deserializedCat instanceof Cat) {
            Cat deserializedCat1 = (Cat) deserializedCat;
            System.out.println(deserializedCat1.getColor());
        }
    }
}

以上代码中,我们首先使用ObjectMapper类将Dog对象和Cat对象序列化为JSON字符串,然后通过readValue方法将JSON字符串反序列化为Animal对象。最后,根据实际的类型进行类型转换。

在序列化过程中,@JsonTypeInfo注解将类型信息包括在JSON字符串中的"type"字段中。在反序列化过程中,根据"type"字段的值来决定具体的子类类型。

相关推荐
小兔崽子去哪了2 小时前
Java 自动化部署
java·后端
ma_king2 小时前
入门 java 和 数据库
java·数据库·后端
后端AI实验室2 小时前
我用Cursor开发了3个月,整理出这套提效4倍的工作流
java·ai
码路飞6 小时前
GPT-5.3 Instant 终于学会好好说话了,顺手对比了下同天发布的 Gemini 3.1 Flash-Lite
java·javascript
SimonKing7 小时前
OpenCode AI编程助手如何添加Skills,优化项目!
java·后端·程序员
Seven979 小时前
剑指offer-80、⼆叉树中和为某⼀值的路径(二)
java
怒放吧德德20 小时前
Netty 4.2 入门指南:从概念到第一个程序
java·后端·netty
雨中飘荡的记忆1 天前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
心之语歌1 天前
基于注解+拦截器的API动态路由实现方案
java·后端
华仔啊1 天前
Stream 代码越写越难看?JDFrame 让 Java 逻辑回归优雅
java·后端