Kryo

使用Kryo序列化和反序列化
https://github.com/EsotericSoftware/kryo
工具類:

package com.gillion.cache.manager.utils;


import com.esotericsoftware.kryo.Kryo;
import com.esotericsoftware.kryo.Registration;
import com.esotericsoftware.kryo.io.Input;
import com.esotericsoftware.kryo.io.Output;

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.util.Collection;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;

/**
 * 使用Kryo序列化對象幫助類
 * Created by admin on 2017/4/17.
 */
public class KryoUtil {

    private static final ThreadLocal<Kryo> kryos = new ThreadLocal<Kryo>() {
        protected Kryo initialValue() {
            Kryo kryo = new Kryo();
            // configure kryo instance, customize settings
            kryo.setReferences(false);
            kryo.register(Collection.class);
            kryo.register(Map.class);
            return kryo;
        }
    };
    private static Map<Class, Registration> registrationMap = new ConcurrentHashMap<Class, Registration>();

    /**
     * 序列化
     *
     * @param obj 序列化對象
     * @return 序列化后的byte[]值
     */
    public static <T> byte[] serializer(T obj) {
        Class<T> clazz = (Class<T>) obj.getClass();
        Kryo kryo = kryos.get();
        if (!registrationMap.containsKey(clazz)) {
            Registration registration = kryo.register(clazz);
            registrationMap.put(clazz, registration);
        }
        ByteArrayOutputStream outputStream = null;
        Output output = null;
        byte[] bytes;
        try {
            outputStream = new ByteArrayOutputStream();
            output = new Output(outputStream);
            kryo.writeObject(output, obj);
            output.flush();
            bytes = outputStream.toByteArray();
            return bytes;
        } finally {
            try {
                if (output != null) {
                    output.close();
                }
                if (outputStream != null) {
                    outputStream.close();
                }
            } catch (Exception ignore) {

            }
        }

    }

    /**
     * 反序列化
     *
     * @param data  序列化后的byte[]值
     * @param clazz 反序列化后的對象
     * @return 返回的對象
     */

    public static <T> T deserializer(byte[] data, Class<T> clazz) {
        Kryo kryo = kryos.get();
        Registration registration = registrationMap.get(clazz);
        if (registration == null) {
            registration = kryo.register(clazz);
            registrationMap.put(clazz, registration);
        }
        T object = null;
        ByteArrayInputStream byteArrayInputStream = null;
        Input input;
        try {
            byteArrayInputStream = new ByteArrayInputStream(data);
            input = new Input(byteArrayInputStream);
            object = (T) kryo.readObject(input, registration.getType());
            input.close();
        } finally {
            try {
                if (byteArrayInputStream != null) {
                    byteArrayInputStream.close();
                }
            } catch (IOException ignore) {
            }
        }
        return object;
    }

}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市日丹,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌坏平,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,482評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件锦亦,死亡現(xiàn)場離奇詭異舶替,居然都是意外死亡,警方通過查閱死者的電腦和手機杠园,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評論 2 382
  • 文/潘曉璐 我一進店門顾瞪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人返劲,你說我怎么就攤上這事玲昧。” “怎么了篮绿?”我有些...
    開封第一講書人閱讀 152,762評論 0 342
  • 文/不壞的土叔 我叫張陵孵延,是天一觀的道長。 經常有香客問我亲配,道長尘应,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,273評論 1 279
  • 正文 為了忘掉前任吼虎,我火速辦了婚禮犬钢,結果婚禮上,老公的妹妹穿的比我還像新娘思灰。我一直安慰自己玷犹,他們只是感情好,可當我...
    茶點故事閱讀 64,289評論 5 373
  • 文/花漫 我一把揭開白布洒疚。 她就那樣靜靜地躺著歹颓,像睡著了一般。 火紅的嫁衣襯著肌膚如雪油湖。 梳的紋絲不亂的頭發(fā)上巍扛,一...
    開封第一講書人閱讀 49,046評論 1 285
  • 那天,我揣著相機與錄音乏德,去河邊找鬼撤奸。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的胧瓜。 我是一名探鬼主播矢棚,決...
    沈念sama閱讀 38,351評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼贷痪!你這毒婦竟也來了奥裸?” 一聲冷哼從身側響起宠漩,我...
    開封第一講書人閱讀 36,988評論 0 259
  • 序言:老撾萬榮一對情侶失蹤煎娇,失蹤者是張志新(化名)和其女友劉穎卵蛉,沒想到半個月后粗仓,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體翘簇,經...
    沈念sama閱讀 43,476評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡溉愁,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,948評論 2 324
  • 正文 我和宋清朗相戀三年攻锰,在試婚紗的時候發(fā)現(xiàn)自己被綠了偶洋。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片熟吏。...
    茶點故事閱讀 38,064評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖玄窝,靈堂內的尸體忽然破棺而出牵寺,到底是詐尸還是另有隱情,我是刑警寧澤恩脂,帶...
    沈念sama閱讀 33,712評論 4 323
  • 正文 年R本政府宣布帽氓,位于F島的核電站,受9級特大地震影響俩块,放射性物質發(fā)生泄漏黎休。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,261評論 3 307
  • 文/蒙蒙 一玉凯、第九天 我趴在偏房一處隱蔽的房頂上張望势腮。 院中可真熱鬧,春花似錦漫仆、人聲如沸捎拯。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽署照。三九已至,卻和暖如春狸眼,著一層夾襖步出監(jiān)牢的瞬間藤树,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評論 1 262
  • 我被黑心中介騙來泰國打工拓萌, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留岁钓,地道東北人。 一個月前我還...
    沈念sama閱讀 45,511評論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像屡限,于是被迫代替她去往敵國和親品嚣。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,802評論 2 345

推薦閱讀更多精彩內容