国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

對象的序列化存儲:Serializable 和 Parceable

移動開發 Android
簡單來說,序列化就是將我們生成的對象進行存儲起來(比如磁盤上),以用來將來使用或者在網絡上進行傳輸,而反序列化呢,就是由我們的之前序列化生成的二進制串重新生成對象的過程。注意,這里我們反復說的序列化啦,反序列化啦,都是針對的對象,而非類。

在進行Android開發的時候我們有時候需要用到數據的持久化存儲,或者在進程之間傳遞數據。其中就可能需要用到對象的序列化,經過序列化的對象之后可以通過Intent或者Boundle來傳輸了。接下來還是想些介紹下吧。

1.什么叫序列化,什么叫反序列化

序列化: 將數據結構或對象轉換成二進制串的過程。反序列化:將在序列化過程中所生成的二進制串轉換成數據結構或者對象的過程。

簡單來說,序列化就是將我們生成的對象進行存儲起來(比如磁盤上),以用來將來使用或者在網絡上進行傳輸,而反序列化呢,就是由我們的之前序列化生成的二進制串重新生成對象的過程。注意,這里我們反復說的序列化啦,反序列化啦,都是針對的對象,而非類。因為我們是針對對象進行存取與傳輸的,而非類,當我們需要重新獲取之前的對象的時候,是直接讀取出來的(從文件或網絡中),而非根據類new出一個對象,這點是需要注意的。

2.如何序列化

序列話的方式有兩種,一種是實現Serializable接口,一種是實現Parceable接口,下面會具體介紹這兩種方式。

a.實現Serializable接口

這種序列化方式是Java提供的,它的優點是簡單,其實Serializable接口是個空接口,因而我們并不需要實現什么抽象方法,但是我們卻往往需要在類中聲明一個靜態變量標識(serialVersionUID),但這不是必須的,我們不聲明,依然可以實現序列化,但是這樣的話會對反序列化產生一定的影響,可能會在我們對類做了修改之后而造成對象的反序列化失敗。聲明方式如下:

  1. private static final long serialVersionUID = 8711368828010083044L; 

注意,這里的值可以是任意值。

下面我們來具體實現下。

  1. package com.qc.admin.myserializableparceabledemo; 
  2.  
  3. import java.io.Serializable
  4.  
  5. /** 
  6.  * Created by admin on 2016/12/1. 
  7.  */ 
  8.  
  9. public class User implements Serializable { 
  10.  
  11.     private static final long serialVersionUID = 519067123721295773L; 
  12.  
  13.     public int userId; 
  14.     public String userName; 
  15.     public boolean isMale; 
  16.  
  17.     public User(int userId, String userName, boolean isMale) { 
  18.  
  19.         this.userId = userId; 
  20.         this.userName = userName; 
  21.         this.isMale = isMale; 
  22.  
  23.     } 
  24.  
  25.     @Override 
  26.     public String toString() { 
  27.         return "User{ " + 
  28.                 "userId = " + userId + 
  29.                 ", userName = " + userName + 
  30.                 ", isMale = " + isMale + 
  31.                 " }"
  32.     } 
  33.  

下面是序列化與反序列化過程: 

  1. private void beginSerizable() throws IOException, ClassNotFoundException { 
  2.  
  3.         // 序列化 
  4.         User user = new User(2016, "qian"true); 
  5.         ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream(new File(getFilesDir(), "myfile.txt"))); 
  6.         out.writeObject(user); 
  7.         out.close(); 
  8.  
  9.         // 反序列化 
  10.         // 注意,這里后面的“/myfile.txt”前面有個斜杠“/”,否則會報“FileNotFoundException”異常 
  11.         ObjectInputStream in = new ObjectInputStream(new FileInputStream(getFilesDir() + "/myfile.txt")); 
  12.         User mUser = (Userin.readObject(); 
  13.         textView.setText(mUser.toString()); 
  14.         in.close(); 
  15.         Log.i("test",mUser.toString()); 
  16.     }  

運行結果截圖: 

 

 

 

注意:如果是在Android項目中調用以上方法,別忘了在Manifest.xml文件中配置如下權限:

  1. <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/> 
  2. <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>  

b.實現Parceable接口

這種方式是Android提供的方式,相比較前面那種方式來講,這種方式稍微有點復雜,我們需要自己盡享序列化與反序列化的操作,但是它卻更加高效,并不需要執行大量的I/O操作。而且這種方式也是Android推薦的序列化方式,因此我們應該***Parceable。只要實現了這個接口,一個類的對象就可以實現序列化并可以通過Intent和Binder進行傳遞了。下面請看實例: 

  1. public class Book implements Parcelable { 
  2.     public String bookTitle; 
  3.     public int bookId; 
  4.  
  5.     protected Book(Parcel in) { 
  6.         bookTitle = in.readString(); 
  7.         bookId = in.readInt(); 
  8.     } 
  9.  
  10.     public static final Creator<Book> CREATOR = new Creator<Book>() { 
  11.         @Override 
  12.         public Book createFromParcel(Parcel in) { 
  13.             return new Book(in); 
  14.         } 
  15.  
  16.         @Override 
  17.         public Book[] newArray(int size) { 
  18.             return new Book[size]; 
  19.         } 
  20.     }; 
  21.  
  22.     @Override 
  23.     public int describeContents() { 
  24.         return 0; 
  25.     } 
  26.  
  27.     @Override 
  28.     public void writeToParcel(Parcel parcel, int i) { 
  29.         parcel.writeString(bookTitle); 
  30.         parcel.writeInt(bookId); 
  31.     } 
  32.  

這里將Book這個類就實現了Parcelable接口,其實在Android Studio IDE中,上述過程很簡單,我們只需要定義一個類,實現Parcelable接口,然后在里面定義我們的屬性或者說是字段,根據提示的錯誤,按照它提示的方法覆蓋相應的方法,之后的一切其實都可以自動生成(不過如果需要構造方法的話,那就需要自動生成了,toString()方法也是自己實現的),所以不用擔心在Android開發中通過實現Parceable接口會比較麻煩,因為AS都會為你自動生成。上面我們已經完整的將Book類實現了Parceable接口,那接下來如何序列化和反序列化呢?如果你說,剛才不是已經說過了嗎,采用文件讀取的方式不久可以了啦...當你那樣做的時候,你會發現會報如下的錯誤: 

 

 

 

Why???...什么情況?提示我們Book類沒有實現序列化:

  1. /System.err: java.io.NotSerializableException: com.qc.admin.myserializableparceabledemo.Book 

好啦,之所以出現這種問題,并不是我們的實現過程有問題,而是使用該類的方式行不通。到這里我們就明白了Serializable和Parceable兩種方式實現序列化還是有區別的,剛才我們也講了,Parceable更加高效,不會像Serializable那樣有大量的I/O操作,這句話的具體含義就道出了Serializable與Parcelable區別:雖然兩者都是用于支持序列化、反序列化話操作,但是兩者***的區別在于存儲媒介的不同,Serializable是將序列化后的對象存儲在硬盤上,使用I/O讀寫的方式,而Parcelable是將其存儲在內存中,是針對內存的讀寫,熟悉計算機組成原理的朋友都知道,內存的讀寫速度顯然要遠遠大于I/O的讀寫速度,這也是為什么Android中推薦使用Parcelable這種方式來實現對象的序列化。

那我們應該怎么使用通過實現Parcelable接口實現序列化的對象呢?答案是:通過Intent方式傳遞,除了基本類型外,Intent只能傳輸序列化之后的對象,對應這兩種序列化方式,也有兩種相應的方法:

  1. mIntent.getSerializableExtra(string name );  
  1. mIntent.getParcelableExtra(String name ); 

當然,放入的操作就沒有這種區分了,都是方法:

  1. mIntent.putExtra(); 

我們可以在***個Activity中將序列化對象放入Intent,在另一個Activity中取出,比如:在另一端獲取對象,例如: 

  1. Bundle mBundle = getIntent().getExtras(); 
  2. Book mBook = mBundle.getParcelable("book1");  

下面再看類User實現Parceable接口的過程,它內部包含了一個可序列化的類Book,具體細節跟上面的有點不同:

  1. package com.qc.admin.myserializableparceabledemo; 
  2.  
  3. import android.os.Parcel; 
  4. import android.os.Parcelable; 
  5.  
  6. /** 
  7.  * Created by admin on 2016/12/1. 
  8.  */ 
  9.  
  10. public class User implements Parcelable { 
  11.  
  12.     public int userId; 
  13.     public String userName; 
  14.     public boolean isMale; 
  15.     public Book book; 
  16.  
  17.  
  18.     public User(int userId, String userName, boolean isMale, Book book) { 
  19.  
  20.         this.userId = userId; 
  21.         this.userName = userName; 
  22.         this.isMale = isMale; 
  23.         this.book = book; 
  24.     } 
  25.  
  26.  
  27.     protected User(Parcel in) { 
  28.         userId = in.readInt(); 
  29.         userName = in.readString(); 
  30.         isMale = in.readByte() != 0; 
  31.         // 此為不同之處1 
  32.         // 也可以通過這種方式:book = in.readParcelable(Thread.currentThread().getContextClassLoader()); 
  33.         book = in.readParcelable(Book.class.getClassLoader()); 
  34.          
  35.     } 
  36.  
  37.     public static final Creator<User> CREATOR = new Creator<User>() { 
  38.         @Override 
  39.         public User createFromParcel(Parcel in) { 
  40.             return new User(in); 
  41.         } 
  42.  
  43.         @Override 
  44.         public User[] newArray(int size) { 
  45.             return new User[size]; 
  46.         } 
  47.     }; 
  48.  
  49.  
  50.     // 幾乎在所有的情況下都應該返回0,只有在當前對象中存在文件描述的時候,此方法返回CONTENTS_FILE_DESCRIPTOR(常量值為1) 
  51.     @Override 
  52.     public int describeContents() { 
  53.         return 0; 
  54.     } 
  55.  
  56.     // 將對象寫入序列化結構中,其中i標識有兩種值,0或者1(PARCELABLE_WRITE_RETURN_VALUE) 
  57.     // 為1時表示當前對象需要作為返回值返回,不能立即釋放資源,幾乎所有情況都為0 
  58.     @Override 
  59.     public void writeToParcel(Parcel parcel, int i) { 
  60.         parcel.writeInt(userId); 
  61.         parcel.writeString(userName); 
  62.         // 注意這里,并不是直接寫入boolean值,而是寫入整數值 
  63.         parcel.writeByte((byte) (isMale ? 1 : 0)); 
  64.         // 此為不同之處2 
  65.         parcel.writeParcelable(book, i); 
  66.     } 
  67.  
  68.     @Override 
  69.     public String toString() { 
  70.         return "User{ " + 
  71.                 "userId = " + userId + 
  72.                 ", userName = " + userName + 
  73.                 ", isMale = " + isMale + 
  74.                 "book = " + book.toString() + 
  75.                 " }"
  76.     } 
  77.  
  78.  

可以看出,結果已經正確的打印了出來了: 

 

 

 

注意:在 Parcelable 中,我們無法直接寫入 boolean 值,而是將其轉化為整數值進行保存,這里為 Byte,當然,你也可以使用 Int 等。

責任編輯:龐桂玉 來源: segmentfault
相關推薦

2011-06-01 15:05:02

序列化反序列化

2009-06-14 22:01:27

Java對象序列化反序列化

2011-06-01 15:18:43

Serializabl

2009-09-09 14:45:41

XML序列化和反序列化

2009-09-09 15:47:27

XML序列化和反序列化

2018-03-19 10:20:23

Java序列化反序列化

2012-04-13 10:45:59

XML

2011-05-18 15:20:13

XML

2009-08-24 17:14:08

C#序列化

2024-03-05 12:49:30

序列化反序列化C#

2009-08-06 11:16:25

C#序列化和反序列化

2021-08-30 12:25:12

Python序列化函數

2019-11-20 10:07:23

web安全PHP序列化反序列化

2009-08-25 14:24:36

C#序列化和反序列化

2011-06-01 14:26:11

序列化

2009-07-29 13:39:02

JSON序列化和反序列ASP.NET AJA

2010-03-19 15:54:21

Java Socket

2022-08-06 08:41:18

序列化反序列化Hessian

2009-03-10 13:38:01

Java序列化字節流

2009-08-25 14:43:26

C#序列化和反序列化
點贊
收藏

51CTO技術棧公眾號

蜜桃a∨噜噜一区二区三区| 婷婷亚洲五月| 色猫猫国产区一区二在线视频| 又粗又黑又大的吊av| 人禽交欧美网站| 国产精品久久久久久久久婷婷| 四虎5151久久欧美毛片| 亚洲性生活视频| 啦啦啦中文在线观看日本| 欧美日韩国产一二三| 欧美一区二区三区少妇| 成人欧美一区二区三区视频网页| 日韩精品一区中文字幕| 91一区二区三区在线播放| 午夜久久久久久久久久久| 日韩电影一区二区三区四区| 久久久com| 欧美三级情趣内衣| 国产深夜精品福利| 国产国产精品| 91色视频在线导航| 欧美阿v一级看视频| 97中文在线观看| 亚洲经典自拍| 色综合电影网| 国产九色精品成人porny| 欧美做暖暖视频| 26uuu色噜噜精品一区二区| 久久久999免费视频| 中文字幕免费不卡在线| 日日噜噜噜夜夜爽爽狠狠| 欧美网站在线观看| 久草免费在线| 一色桃子一区二区| 好吊妞国产欧美日韩免费观看网站| 91极品女神在线| 91综合久久一区二区| 精品久久久久久一区二区里番| 亚洲欧美久久| 国产精品成人久久电影| 中国av一区二区三区| 免费在线看污| 91精品国产色综合久久ai换脸 | 日韩毛片久久久| 亚洲国产美女精品久久久久∴| 在线观看v片| 欧美激情中文字幕在线| 91精品一区二区三区综合| 国产精品久久精品视| 老司机一区二区| 国产 日韩 欧美在线| 亚洲精品成人在线| 国产网友自拍视频导航网站在线观看| 亚洲色图美腿丝袜| 亚洲资源网站| 欧美一区二区影视| 日韩毛片免费看| 亚洲精品一区二区三区蜜桃下载| 500福利第一精品导航| 国产情人综合久久777777| 精品国产乱码久久久久久樱花| 亚洲精品成人无限看| 国产精品久久久久久福利| 亚洲午夜在线观看| 欧美午夜女人视频在线| 日本精品在线中文字幕| 97超碰免费观看| 久久国产精品首页| 亚洲国产精品久久不卡毛片| 亚洲一区自拍| 一区二区三区视频播放| 天天槽夜夜槽| 五月天亚洲综合情| 国产精品狠色婷| 午夜亚洲福利老司机| 中文字幕日韩av综合精品| 蜜桃精品视频| 日韩国产一级片| 97视频在线观看免费| 91色综合久久久久婷婷| 亚洲最新无码中文字幕久久| 美女av一区二区三区| 久久成人免费网| 熟妇人妻va精品中文字幕| 久久久久久亚洲综合影院红桃| 久久精品视频91| 亚洲少妇激情视频| 国产精品日本| 在线观看日韩片| 欧美网站大全在线观看| 91九色综合| 久久精品影视大全| 国产综合18久久久久久| 91国内在线视频| 欧美人狂配大交3d怪物一区| 97超碰欧美中文字幕| 国产亚洲毛片| 国产精品hd| a级在线观看| av磁力番号网| 国内精品小视频| 亚洲第一精品福利| 91久久精品网| 1024亚洲合集| 欧美日韩在线视频一区二区| 亚洲一二三四区| 亚洲精品久久久久久国产精华液| 国产一区二区精品久久99| 久久99精品久久久| 久久色在线视频| 麻豆传媒在线播放| 国产成人91久久精品| 亚洲视频免费观看| 青青草国产免费一区二区下载 | 欧美爱爱视频| 欧美牲交a欧美牲交aⅴ免费真| 美女av一区二区| 99视频这里有精品| 在线播放日本| 无码人妻丰满熟妇区毛片18| 国产精品视频一区二区高潮| 精品亚洲一区二区三区在线观看| 韩国三级在线一区| 国产成+人+综合+亚洲欧美| 国产精品揄拍500视频| 91久久线看在观草草青青 | 91美女主播在线视频| 欧美大香线蕉线伊人久久| 韩日视频在线观看| 日韩高清欧美高清| 成人免费毛片高清视频| 亚洲网址在线观看| 写真片福利在线播放| 91视频免费进入| 欧美精品一区二区三区在线播放| 国产美女精品一区二区三区| 亚洲男人在线| 91se在线观看| 神马影院我不卡| 欧美日本国产在线| 一本到一区二区三区| 久久精品国产免费| 国偷自产av一区二区三区| 浮生影视网在线观看免费| 一本久久a久久精品vr综合| 九色91av视频| 色婷婷综合激情| 懂色av中文字幕一区二区三区| 久久99免费视频| 日本一级理论片在线大全| aaa毛片在线观看| 超碰97在线播放| 色先锋资源久久综合5566| 亚洲在线成人精品| 日本中文字幕不卡| 精品少妇3p| 污污视频在线| 蜜桃传媒九九九| 色噜噜色狠狠狠狠狠综合色一| 亚洲视频999| 亚洲成人免费av| 国产一区二区三区久久久| 精品色999| 美女日韩欧美| 在线观看免费观看在线91| 黄色片免费在线观看视频| 国产欧美日韩中文字幕在线| 七七成人影院| 激情自拍一区| 九九视频精品免费| 色综合久久99| 精品播放一区二区| 亚洲香蕉成人av网站在线观看| 91免费视频国产| 亚洲第一在线视频| 亚洲午夜av在线| 成人黄色在线网站| 亚洲高清网站| 哺乳挤奶一区二区三区免费看| dj大片免费在线观看| 91大神网址| 精品国产一区二区三区无码| 91影视免费在线观看| 欧美高清在线视频观看不卡| 日韩欧美一区二区不卡| 午夜成人免费电影| 国产日产精品1区| 国产一区二区三区av电影| 欧美日韩 国产精品| 一区二区三区高清在线观看| 丁香花在线高清完整版视频| 污网站视频在线观看| 天天干天天玩天天操| 青青草国产免费| 欧美性大战久久久久| 亚洲综合自拍一区| 国产精品福利在线| 91精品国产高清久久久久久| 美腿丝袜亚洲三区| 欧美精品自拍偷拍|