• Json解析工具Jackson(简单应用)


    概述
        Jackson库(http://jackson.codehaus.org),是基于Java语言的开源json格式解析工具,整个库(使用最新的2.2版本)包含3个jar包:
        jackson-core.jar——核心包(必须),提供基于“流模式”解析的API。
        jackson-databind——数据绑定包(可选),提供基于“对象绑定”和“树模型”相关API。
        jackson-annotations——注解包(可选),提供注解功能。
    Jackson的优势
        相对于Java json解析的其他库,诸如json-lib、gson包,Jackson具有以下优点:
        1.功能全面,提供多种模式的json解析方式,“对象绑定”使用方便,利用注解包能为我们开发提供很多便利。
        2.性能较高,“流模式”的解析效率超过绝大多数类似的json包。
    重要API
        核心包:JsonPaser(json流读取),JsonGenerator(json流输出)。
        数据绑定包:ObjectMapper(构建树模式和对象绑定模式),JsonNode(树节点)。
    简单例子
        在实际应用中,用的最多的是数据对象绑定的模式,即将一个对象序列化为json字符串和将一串json字符串反序列化为java对象或Map。

    Person类:

    public class Person {
    
        private String name;
    
        private Integer age;
    
        //必须的
        public Person() {
        }
    
        public Person(String name, Integer age) {
            this.name = name;
            this.age = age;
        }
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public Integer getAge() {
            return age;
        }
    
        public void setAge(Integer age) {
            this.age = age;
        }
    }

    测试类

    /**
     * 示例本身很简单,但是main方法中的写法很值得借鉴
     * 重构的思想
     */
    public class Demo {
        public static void main(String[] args) {
    
            //writeJsonObject();
    
            //readJsonObject();
    
            readJsonMap();
        }
    
        //直接写入一个对象(序列化)
        public static void writeJsonObject() {
            ObjectMapper mapper = new ObjectMapper();
            Person person = new Person("nomouse", 25);
            try {
                mapper.writeValue(new File("c:/person.json"), person);
                String string = mapper.writeValueAsString(person);
                System.out.println(string);
            } catch (JsonGenerationException e) {
                e.printStackTrace();
            } catch (JsonMappingException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    
        // 直接将一个json转化为对象(反序列化)
        public static void readJsonObject() {
            ObjectMapper mapper = new ObjectMapper();
    
            try {
                Person person = mapper.readValue(new File("c:/person.json"),
                        Person.class);
                System.out.println(person.getName() + ":" + person.getAge());
                String string = "{"name":"nomouse","age":25}";
                //Person必须有无参构造方法
                Person person1 = mapper.readValue(string, Person.class);
                System.out.println(person1.getName() + ":" + person1.getAge());
    
            } catch (JsonParseException e) {
                e.printStackTrace();
            } catch (JsonMappingException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    
        // 直接转化为map
        public static void readJsonMap() {
            ObjectMapper mapper = new ObjectMapper();
    
            try {
                // 需要注意的是这里的Map实际为一个LikedHashMap,即链式哈希表,可以按照读入顺序遍历
                Map map = mapper.readValue(new File("c:/person.json"), Map.class);
                System.out.println(map.get("name") + ":" + map.get("age"));
                String string = "{"name":"nomouse","age":25}";
                //Person必须有无参构造方法
                Map map1 = mapper.readValue(string, Map.class);
                System.out.println(map1);
            } catch (JsonParseException e) {
                e.printStackTrace();
            } catch (JsonMappingException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    
    }
  • 相关阅读:
    【POJ 1655】Balancing Act
    【POJ 2631】 Roads in the North
    【洛谷 1002】 过河卒
    【洛谷 3178】树上操作
    【洛谷 1060】开心的金明
    【洛谷 2709】小B的询问
    【洛谷 1972】HH的项链
    JavaSpark-sparkSQL
    java8下spark-streaming结合kafka编程(spark 2.3 kafka 0.10)
    Kafka 使用Java实现数据的生产和消费demo
  • 原文地址:https://www.cnblogs.com/winner-0715/p/6121504.html
Copyright © 2020-2023  润新知