乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      jackson學習之八:常用方法注解

       Coder編程 2021-05-06


      https://github.com/zq2599/blog_demos

      內(nèi)容:所有原創(chuàng)文章分類匯總及配套源碼,涉及Java、Docker、Kubernetes、DevOPS等;

      系列文章匯總

      本篇概覽

      • 本文是《jackson學習》系列的第八篇,繼續(xù)學習jackson強大的注解能力,本篇學習常用的方法注解,并通過實例來加深印象,下圖是常用方法注解的簡介:

      在這里插入圖片描述

      源碼下載

      1. 如果您不想編碼,可以在GitHub下載所有源碼,地址和鏈接信息如下表所示(https://github.com/zq2599/blog_demos):

      名稱鏈接備注
      項目主頁https://github.com/zq2599/blog_demos該項目在GitHub上的主頁
      git倉庫地址(https)https://github.com/zq2599/blog_demos.git該項目源碼的倉庫地址,https協(xié)議
      git倉庫地址(ssh)git@github.com:zq2599/blog_demos.git該項目源碼的倉庫地址,ssh協(xié)議
      1. 這個git項目中有多個文件夾,本章的應用在jacksondemo文件夾下,如下圖紅框所示:

      在這里插入圖片描述

      1. jacksondemo是父子結構的工程,本篇的代碼在annotation子工程中,里面的methodannotation這個package下,如下圖:

      在這里插入圖片描述

      JsonValue

      1. 在序列化時起作用,可以用來注解get方法或者成員變量;

      2. 一個類中,JsonValue只允許出現(xiàn)一次;

      3. 如果注解的是get方法,那么該方法的返回值就是整個實例的序列化結果;

      4. 如果注解的是成員變量,那么該成員變量的值就是整個實例的序列化結果;

      5. 下面是用來測試的Pojo類,JsonValue注解放在getField0方法上,此方法的返回值已經(jīng)寫死了"abc":

          static class Test {
      
              private String field0;
      
              private String field1;
      
              @JsonValue
              public String getField0() { return "abc"; }
      
              public void setField0(String field0) { this.field0 = field0; }
              public String getField1() { return field1; }
              public void setField1(String field1) { this.field1 = field1; }
          }
      1. Test類的序列化結果如下,即getField0方法的返回值:

      在這里插入圖片描述

      JsonCreator

      1. 在反序列化時,當出現(xiàn)有參構造方法時(可能是多個有參構造方法),需要通過JsonCreator注解指定反序列化時用哪個構造方法,并且在入?yún)⑻庍€要通過JsonProperty指定字段關系:

          static class Test {
      
              private String field0;
              private String field1;
      
      
              public Test(String field0) {
                  this.field0 = field0;
              }
      
              // 通過JsonCreator指定反序列化的時候使用這個構造方法
              // 通過JsonProperty指定字段關系
              @JsonCreator
              public Test(@JsonProperty("field0") String field0,
                          @JsonProperty("field1") String field1) {
                  this.field0 = field0;
                  this.field1 = field1;
              }
      
              @Override
              public String toString() {
                  return "Test{" +
                          "field0='" + field0 + '\'' +
                          ", field1='" + field1 + '\'' +
                          '}';
              }
          }
      1. 反序列化結果如下:

      在這里插入圖片描述

      JsonSetter

      1. JsonSetter注解在set方法上,被用來在反序列化時指定set方法對應json的哪個屬性;

      2. JsonSetter源碼中,推薦使用JsonProperty來取代JsonSetter:

      在這里插入圖片描述
      3. 測試代碼和結果如下,可見反序列化時,是按照JsonSetter的value去json中查找屬性的:

      在這里插入圖片描述

      JsonGetter

      1. JsonGetter只能作為方法注解;

      2. 在序列化時,被JsonGetter注解的get方法,對應的json字段名是JsonGetter的value;

      3. JsonGetter源碼中,推薦使用JsonProperty來取代JsonGetter:

      在這里插入圖片描述
      4. 測試代碼和結果如下,可見序列化時JsonGetter的value會被作為json字段名:

      在這里插入圖片描述

      JsonAnyGetter

      1. JsonAnyGetter的作用有些特別:在序列化時,用Map對象的鍵值對轉(zhuǎn)成json的字段和值;

      2. 理解JsonAnyGetter最好的辦法,是對比使用前后序列化結果的變化,先來看以下這段代碼,是沒有JsonAnyGetter注解的,Test有兩個成員變量,其中map字段是HashMap類型的:

      package com.bolingcavalry.jacksondemo.annotation.methodannotation;
      
      import com.fasterxml.jackson.annotation.JsonAnyGetter;
      import com.fasterxml.jackson.databind.ObjectMapper;
      import com.fasterxml.jackson.databind.SerializationFeature;
      
      import java.util.HashMap;
      import java.util.Map;
      
      public class JsonAnySetterSerialization {
      
          static class Test {
              private String field0;
              private Map<String, Object> map;
      
              public String getField0() { return field0; }
              public void setField0(String field0) { this.field0 = field0; }
              public void setMap(Map<String, Object> map) { this.map = map; }
              public Map<String, Object> getMap() { return map; }
          }
      
          public static void main(String[] args) throws Exception {
              ObjectMapper mapper = new ObjectMapper();
              // 美化輸出
              mapper.enable(SerializationFeature.INDENT_OUTPUT);
      
              // 新增一個HashMap,里面放入兩個元素
              Map<String, Object> map = new HashMap<>();
              map.put("aaa", "value_aaa");
              map.put("bbb", "value_bbb");
      
              Test test = new Test();
              test.setField0("000");
      
              // map賦值給test.map
              test.setMap(map);
      
              System.out.println(mapper.writeValueAsString(test));
          }
      }
      1. 上述代碼的執(zhí)行結果如下,其實很好理解,就是field0和map兩個字段而已:

      {
        "field0" : "000",
        "map" : {
          "aaa" : "value_aaa",
          "bbb" : "value_bbb"
        }
      }
      1. 接下來,對上述代碼做一處改動,如下圖紅框所示,給getMap方法增加JsonAnyGetter注解:

      在這里插入圖片描述
      5. 修改后的執(zhí)行結果如下,原來的map字段沒有了,map內(nèi)部的所有鍵值對都成了json的字段:

      {
        "field0" : "000",
        "aaa" : "value_aaa",
        "bbb" : "value_bbb"
      }
      1. 至此,可以品味出JsonAnyGetter的作用了:序列化時,將Map中的鍵值對全部作為JSON的字段輸出

      JsonAnySetter

      1. 弄懂了前面的JsonAnyGetter,對于JsonAnySetter的作用想必您也能大致猜到:反序列化時,對json中不認識的字段,統(tǒng)統(tǒng)調(diào)用JsonAnySetter注解修飾的方法去處理;

      2. 測試的代碼如下,Test類的setValue方法被JsonAnySetter注解,在反序列化時,json中的aaabbb字段,都會交給setValue方法處理,也就是放入map中:

      package com.bolingcavalry.jacksondemo.annotation.methodannotation;
      
      import com.fasterxml.jackson.annotation.JsonAnySetter;
      import com.fasterxml.jackson.annotation.JsonCreator;
      import com.fasterxml.jackson.annotation.JsonProperty;
      import com.fasterxml.jackson.databind.ObjectMapper;
      
      import java.util.HashMap;
      import java.util.Map;
      
      public class JsonAnySetterDeserialization {
      
          static class Test {
      
              private String field0;
              
              private Map<String, Object> map = new HashMap<>();
      
              @JsonAnySetter
              public void setValue(String key, Object value) {
                  map.put(key, value);
              }
      
              @Override
              public String toString() {
                  return "Test{" +
                          "field0='" + field0 + '\'' +
                          ", map=" + map +
                          '}';
              }
          }
      
          public static void main(String[] args) throws Exception {
              String jsonStr = "{\n" +
                      "  \"field0\" : \"000\",\n" +
                      "  \"aaa\" : \"value_aaa\",\n" +
                      "  \"bbb\" : \"value_bbb\"\n" +
                      "}";
      
              System.out.println(new ObjectMapper().readValue(jsonStr, Test.class));
          }
      }
      1. 執(zhí)行結果如下,可見aaa、bbb都被放入了map中:

      Test{field0='null', map={aaa=value_aaa, field0=000, bbb=value_bbb}}
      1. 另外JsonAnySetter還可以作用在成員變量上,上面的代碼中,去掉setValue方法,在成員變量map上增加JsonAnySetter注解,修改后如下,執(zhí)行結果也是一模一樣的:

          static class Test {
      
              private String field0;
      
              @JsonAnySetter
              private Map<String, Object> map = new HashMap<>();
      
              @Override
              public String toString() {
                  return "Test{" +
                          "field0='" + field0 + '\'' +
                          ", map=" + map +
                          '}';
              }
          }
      1. 注意,JsonAnySetter作用在成員變量上時,該成員變量必須是java.util.Map的實現(xiàn)類

      • 至此,Jackson常用注解已全部實戰(zhàn)完畢,希望這些豐富的注解能助您制定出各種靈活的序列化和反序列化策略;

      你不孤單,欣宸原創(chuàng)一路相伴

        本站是提供個人知識管理的網(wǎng)絡存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權內(nèi)容,請點擊一鍵舉報。
        轉(zhuǎn)藏 分享 獻花(0

        0條評論

        發(fā)表

        請遵守用戶 評論公約

        類似文章 更多