溫馨提示×

溫馨提示×

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

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

MessagePack Java Jackson Dataformat - POJO 的序列化和反序

發(fā)布時間:2020-06-07 17:36:08 來源:網(wǎng)絡(luò) 閱讀:291 作者:HoneyMoose 欄目:大數(shù)據(jù)

在本測試代碼中,我們定義了一個 POJO 類,名字為?MessageData,你可以訪問下面的鏈接找到有關(guān)這個類的定義。

https://github.com/cwiki-us-demo/serialize-deserialize-demo-java/blob/master/src/main/java/com/insight/demo/serialize/model/msgpack/MessageData.java

POJO 的序列化和反序列化

你僅僅需要對?MessagePackFactory?進行實例化,然后傳遞參數(shù)到?com.fasterxml.jackson.databind.ObjectMapper?的構(gòu)造方法。

然后你就可以用與?jackson-databind?相同的方法使用?MessagePack?格式化數(shù)據(jù)。

本測試方法,可以在?https://github.com/cwiki-us-demo/serialize-deserialize-demo-java/blob/master/src/test/java/com/insight/demo/serialize/MessagePackSerializer.java?中找到。

/**
?*?SerializationPOJO
?*/
@Test
public?void?testMessagePackSerializationPOJO()?{
?
????byte[]?bytes?=?new?byte[0];
????String?uuid?=?UUID.randomUUID().toString();
?
????//?Instantiate?ObjectMapper?for?MessagePack
????ObjectMapper?objectMapper?=?new?ObjectMapper(new?MessagePackFactory());
?
?
????MessageData?pojo?=?new?MessageData();
????pojo.setUuid(uuid);
????pojo.setName("CWIKI.US");
?
?
????try?{
????????//?Serialize?a?Java?object?to?byte?array
????????bytes?=?objectMapper.writeValueAsBytes(pojo);
????????logger.debug("Length?of?Bytes:?[{}]",?bytes.length);
?
????????//?Deserialize?the?byte?array?to?a?Java?object
????????MessageData?deserialized?=?objectMapper.readValue(bytes,?MessageData.class);
????????logger.debug("Deserialized?Name:?[{}]",?deserialized.name);
?
????????assertEquals("CWIKI.US",?deserialized.name);
?
????}?catch?(JsonProcessingException?ex)?{
????????logger.error("Serialize?Error",?ex);
????}?catch?(IOException?e)?{
????????e.printStackTrace();
????}
?
}

https://www.cwiki.us/display/Serialization/MessagePack+Jackson+Dataformat

?


向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI