中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JAVA如何基于SnakeYAML實現序列化YAML

發布時間:2021-09-14 23:31:21 來源:億速云 閱讀:377 作者:chen 欄目:編程語言

這篇文章主要介紹“JAVA如何基于SnakeYAML實現序列化YAML”,在日常操作中,相信很多人在JAVA如何基于SnakeYAML實現序列化YAML問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”JAVA如何基于SnakeYAML實現序列化YAML”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

1.概述

本文,我們將學習如何使用SnakeYAML庫將

YAML文檔轉換為Java對象,以及JAVA對象如何序列化為YAML文檔。

2.項目設置

要在項目中使用SnakeYAML,需要添加Maven依賴項(可在此處找到最新版本):

<dependency>  <groupId>org.yaml</groupId>  <artifactId>snakeyaml</artifactId>  <version>1.25</version></dependency>

3.入口點

該YAML類是API的入口點:

Yaml yaml = new Yaml()

由于實現不是線程安全的,因此不同的線程必須具有自己的Yaml實例。

4.加載YAML文檔

SnakeYAML支持從String或InputStream加載文檔,我們從定義一個簡單的YAML文檔開始,然后將文件命名為customer.yaml:

firstName: "John"lastName: "Doe"age: 20

4.1基本用法

現在,我們將使用Yaml類來解析上述YAML文檔:

Yaml yaml = new Yaml();InputStream inputStream = this.getClass() .getClassLoader() .getResourceAsStream("customer.yaml");Map<String, Object> obj = yaml.load(inputStream);System.out.println(obj);

上面的代碼生成以下輸出:

{firstName=John, lastName=Doe, age=20}

默認情況下,load()方法返回一個Map對象。查詢Map對象時,我們需要事先知道屬性鍵的名稱,否則容易出錯。更好的辦法是自定義類型。

4.2自定義類型解析

SnakeYAML提供了一種將文檔解析為自定義類型的方法

讓我們定義一個Customer類,然后嘗試再次加載該文檔:

public class Customer {   private String firstName;  private String lastName;  private int age;   // getters and setters}

現在我么來加載:

Yaml yaml = new Yaml();InputStream inputStream = this.getClass() .getClassLoader() .getResourceAsStream("customer.yaml");Customer customer = yaml.load(inputStream);

還有一種方法是使用Constructor:

Yaml yaml = new Yaml(new Constructor(Customer.class));

4.3隱式類型

如果沒有為給定屬性定義類型,則庫會自動將值轉換為隱式type。

例如:

1.0 -> Float42 -> Integer2009-03-30 -> Date

讓我們使用一個TestCase來測試這種隱式類型轉換:

@Testpublic void whenLoadYAML_thenLoadCorrectImplicitTypes() {  Yaml yaml = new Yaml();  Map<Object, Object> document = yaml.load("3.0: 2018-07-22");   assertNotNull(document);  assertEquals(1, document.size());  assertTrue(document.containsKey(3.0d));  }

4.4 嵌套對象

SnakeYAML 支持嵌套的復雜類型。

讓我們向“ customer.yaml”添加“ 聯系方式” 和“ 地址” 詳細信息,并將新文件另存為customer_with_contact_details_and_address.yaml.。

現在,我們將分析新的YAML文檔:

firstName: "John"lastName: "Doe"age: 31contactDetails:  - type: "mobile"   number: 123456789  - type: "landline"   number: 456786868homeAddress:  line: "Xyz, DEF Street"  city: "City Y"  state: "State Y"  zip: 345657

我們來更新java類:

public class Customer {  private String firstName;  private String lastName;  private int age;  private List<Contact> contactDetails;  private Address homeAddress;    // getters and setters}public class Contact {  private String type;  private int number;  // getters and setters}public class Address {  private String line;  private String city;  private String state;  private Integer zip;  // getters and setters}

現在,我們來測試下Yaml#load():

@Testpublic void whenLoadYAMLDocumentWithTopLevelClass_thenLoadCorrectJavaObjectWithNestedObjects() {   Yaml yaml = new Yaml(new Constructor(Customer.class));  InputStream inputStream = this.getClass()   .getClassLoader()   .getResourceAsStream("yaml/customer_with_contact_details_and_address.yaml");  Customer customer = yaml.load(inputStream);   assertNotNull(customer);  assertEquals("John", customer.getFirstName());  assertEquals("Doe", customer.getLastName());  assertEquals(31, customer.getAge());  assertNotNull(customer.getContactDetails());  assertEquals(2, customer.getContactDetails().size());     assertEquals("mobile", customer.getContactDetails()   .get(0)   .getType());  assertEquals(123456789, customer.getContactDetails()   .get(0)   .getNumber());  assertEquals("landline", customer.getContactDetails()   .get(1)   .getType());  assertEquals(456786868, customer.getContactDetails()   .get(1)   .getNumber());  assertNotNull(customer.getHomeAddress());  assertEquals("Xyz, DEF Street", customer.getHomeAddress()   .getLine());}

4.5類型安全的集合

當給定Java類的一個或多個屬性是泛型集合類時,需要通過TypeDescription來指定泛型類型,以以便可以正確解析。

讓我們假設一個 一個Customer擁有多個Contact:

firstName: "John"lastName: "Doe"age: 31contactDetails:  - { type: "mobile", number: 123456789}  - { type: "landline", number: 123456789}

為了能正確解析,我們可以在頂級類上為給定屬性指定TypeDescription :

Constructor constructor = new Constructor(Customer.class);TypeDescription customTypeDescription = new TypeDescription(Customer.class);customTypeDescription.addPropertyParameters("contactDetails", Contact.class);constructor.addTypeDescription(customTypeDescription);Yaml yaml = new Yaml(constructor);

4.6載入多個文件

在某些情況下,單個文件中可能有多個YAML文檔,而我們想解析所有文檔。所述YAML類提供了一個LOADALL()方法來完成這種類型的解析。

假設下面的內容在一個文件中:

---firstName: "John"lastName: "Doe"age: 20---firstName: "Jack"lastName: "Jones"age: 25

我們可以使用loadAll()方法解析以上內容,如以下代碼示例所示:

@Testpublic void whenLoadMultipleYAMLDocuments_thenLoadCorrectJavaObjects() {  Yaml yaml = new Yaml(new Constructor(Customer.class));  InputStream inputStream = this.getClass()   .getClassLoader()   .getResourceAsStream("yaml/customers.yaml");   int count = 0;  for (Object object : yaml.loadAll(inputStream)) {    count++;    assertTrue(object instanceof Customer);  }  assertEquals(2,count);}

5.生成YAML文件

SnakeYAML 支持 將java對象序列化為yml。

5.1基本用法

我們將從一個將Map <String,Object>的實例轉儲到YAML文檔(String)的簡單示例開始:

@Testpublic void whenDumpMap_thenGenerateCorrectYAML() {  Map<String, Object> data = new LinkedHashMap<String, Object>();  data.put("name", "Silenthand Olleander");  data.put("race", "Human");  data.put("traits", new String[] { "ONE_HAND", "ONE_EYE" });  Yaml yaml = new Yaml();  StringWriter writer = new StringWriter();  yaml.dump(data, writer);  String expectedYaml = "name: Silenthand Olleander\nrace: Human\ntraits: [ONE_HAND, ONE_EYE]\n";   assertEquals(expectedYaml, writer.toString());}

上面的代碼產生以下輸出(請注意,使用LinkedHashMap的實例將保留輸出數據的順序):

name: Silenthand Olleanderrace: Humantraits: [ONE_HAND, ONE_EYE]

5.2自定義Java對象

我們還可以選擇將自定義Java類型轉儲到輸出流中。

@Testpublic void whenDumpACustomType_thenGenerateCorrectYAML() { Customer customer = new Customer(); customer.setAge(45); customer.setFirstName("Greg"); customer.setLastName("McDowell"); Yaml yaml = new Yaml(); StringWriter writer = new StringWriter(); yaml.dump(customer, writer);   String expectedYaml = "!!com.baeldung.snakeyaml.Customer {age: 45, contactDetails: null, firstName: Greg,\n homeAddress: null, lastName: McDowell}\n";  assertEquals(expectedYaml, writer.toString());}

生成內容會包含!!com.baeldung.snakeyaml.Customer,為了避免在輸出文件中使用標簽名,我們可以使用庫提供的 dumpAs()方法。

因此,在上面的代碼中,我們可以進行以下調整以刪除標記:

yaml.dumpAs(customer, Tag.MAP, null);

到此,關于“JAVA如何基于SnakeYAML實現序列化YAML”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

满洲里市| 西林县| 琼中| 祁阳县| 修水县| 温州市| 马山县| 五指山市| 府谷县| 和平县| 成安县| 蒲城县| 宜春市| 道孚县| 新巴尔虎右旗| 柳河县| 边坝县| 尼勒克县| 马鞍山市| 湘潭市| 东阿县| 阳江市| 大英县| 大竹县| 宁陵县| 理塘县| 呼玛县| 岑溪市| 新郑市| 射阳县| 会宁县| 昭平县| 龙陵县| 水城县| 汾阳市| 谢通门县| 东明县| 周宁县| 象山县| 梁山县| 清远市|