您好,登錄后才能下訂單哦!
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í)。
免責(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)容。