溫馨提示×

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

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

redis能保存對(duì)象嗎

發(fā)布時(shí)間:2020-07-21 13:48:12 來(lái)源:億速云 閱讀:705 作者:Leah 欄目:關(guān)系型數(shù)據(jù)庫(kù)

redis能保存對(duì)象嗎?針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。

  redis是可以存儲(chǔ)對(duì)象的,但是需要用到序列化和反序列化。

為什么要實(shí)現(xiàn)序列化接口?

當(dāng)一個(gè)類實(shí)現(xiàn)了Serializable接口(該接口僅為標(biāo)記接口,不包含任何方法定義),表示該類可以序列化.序列化的目的是將一個(gè)實(shí)現(xiàn)了Serializable接口的對(duì)象轉(zhuǎn)換成一個(gè)字節(jié)序列,可以。 把該字節(jié)序列保存起來(lái)(例如:保存在一個(gè)文件里),以后可以隨時(shí)將該字節(jié)序列恢復(fù)為原來(lái)的對(duì)象。甚至可以將該字節(jié)序列放到其他計(jì)算機(jī)上或者通過(guò)網(wǎng)絡(luò)傳輸?shù)狡渌?jì)算機(jī)上恢復(fù),只要該計(jì) 算機(jī)平臺(tái)存在相應(yīng)的類就可以正?;謴?fù)為原來(lái)的對(duì)象。 實(shí)現(xiàn):要序列化一個(gè)對(duì)象,先要?jiǎng)?chuàng)建某些OutputStream對(duì)象,然后將其封裝在一個(gè)ObjectOutputStream對(duì)象內(nèi),再調(diào)用writeObject()方法即可序列化一個(gè)對(duì)象;反序列化也類似。

注意:使用對(duì)象流寫入到文件是不僅要保證該對(duì)象是序列化的,而且該對(duì)象的成員對(duì)象也必須是序列化的

關(guān)于Serializable接口的類中的serialVersionUID:

serialVersionUID是long類型的。在Eclipse中有兩種生成方式:

默認(rèn)的是1L:

private static final long serialVersionUID = 1L;

另外一個(gè)則是根據(jù)類名、接口名、成員方法以及屬性等生成一個(gè)64位的哈希字段:

private static final long serialVersionUID = 3969438177161438988L;

serialVersionUID主要是為了解決對(duì)象反序列化的兼容性問(wèn)題。

如果沒有提供serialVersionUID,對(duì)象序列化后存到硬盤上之后,再增加或減少類的filed。這樣,當(dāng)反序列化時(shí),就會(huì)出現(xiàn)Exception,造成不兼容問(wèn)題。

但當(dāng)serialVersionUID相同時(shí),它就會(huì)將不一樣的field以type的缺省值反序列化。這樣就可以避開不兼容問(wèn)題了。

以上方式只能恢復(fù)成Java對(duì)象,如果想要恢復(fù)成其他對(duì)象(如C++對(duì)象),那就要將Java對(duì)象轉(zhuǎn)換為XML格式,這樣可以使其被各種平臺(tái)和各種語(yǔ)言使用??梢允褂秒SJDK一起發(fā)布的javax.xam.*類庫(kù),或者使用開源XOM類庫(kù)。

實(shí)驗(yàn)案例:

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import bean.Person;
import redis.clients.jedis.Jedis;
public class SerializeUtil {
    public static void main(String [] args){
        Jedis jedis = new Jedis("172.16.135.2");
        String keys = "name";
        // 刪數(shù)據(jù)
        //jedis.del(keys);
        // 存數(shù)據(jù)
        jedis.set(keys, "zy");
        // 取數(shù)據(jù)
        String value = jedis.get(keys);
        System.out.println(value);
        
        //存對(duì)象
        Person p=new Person();  //peson類記得實(shí)現(xiàn)序列化接口 Serializable
        p.setAge(20);
        p.setName("姚波");
        p.setId(1);
        jedis.set("person".getBytes(), serialize(p));
        byte[] byt=jedis.get("person".getBytes());
        Object obj=unserizlize(byt);
        if(obj instanceof Person){
            System.out.println(obj);
        }
    }
    
    //序列化 
    public static byte [] serialize(Object obj){
        ObjectOutputStream obi=null;
        ByteArrayOutputStream bai=null;
        try {
            bai=new ByteArrayOutputStream();
            obi=new ObjectOutputStream(bai);
            obi.writeObject(obj);
            byte[] byt=bai.toByteArray();
            return byt;
        } catch (IOException e) {
            e.printStackTrace();
        }
        return null;
    }
    
    //反序列化
    public static Object unserizlize(byte[] byt){
        ObjectInputStream oii=null;
        ByteArrayInputStream bis=null;
        bis=new ByteArrayInputStream(byt);
        try {
            oii=new ObjectInputStream(bis);
            Object obj=oii.readObject();
            return obj;
        } catch (Exception e) {
            
            e.printStackTrace();
        }
    
        
        return null;
    }
}

關(guān)于redis能保存對(duì)象嗎問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。

向AI問(wèn)一下細(xì)節(jié)

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

AI