作者s4300026 (s4300026)
看板C_Sharp
標題[問題] 如何根據System.Type做轉型
時間Thu Sep 20 09:43:56 2018
是這樣的
我有寫一個序列化的方法把我的class存檔
BinaryFormatter myBinaryFormatter = new BinaryFormatter();
myBinaryFormatter.Serialize(oFileStream, saveObj);
現在的問題是,我的saveObj會需要與時俱進的新增功能和變數
但每次更新我的class,我的舊的存檔就無法被使用 (因為格式不符)
我目前想到的解決方法是用繼承
像是這樣:主名稱 + 撰寫日期,然後繼承最後一版的class如下
class MyObj180920: object{}
class MyObj180925: MyObj180920{}
class MyObj181001: MyObj180925{}
然後我有個上層class manage
{
Object myObj;
System.Type myObjType;
}
每次我的程式會實體化最新的class和type
myObj = new MyObj180920;
myObjType = (new MyObj180920).GetType();
然後序列化的時候應該(我覺得)會將實作品(MyObj180920)存入硬碟
而非父類別型態(Object)
當我更新版本後(180925)
我期望我的反序列化能根據 myObjType 轉型成正確的過往類別
而不用每次都做轉型判斷
switch (myObj.GetType().Name)
{
case "MyObj180920":
break;
case "MyObj180925":
break;
}
但是我不會用根據System.Type做轉型指令,有人知道要怎麼用嗎?
感謝大家撥冗觀看~
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 60.250.235.221
※ 文章網址: https://webptt.com/m.aspx?n=bbs/C_Sharp/M.1537407838.A.1A0.html
1F:→ awwseed: 弄一個 Interface 讓各個 Class 實作? 09/20 13:16
2F:推 anumis: 有試過json嗎? 09/20 16:40
3F:→ s4300026: awwseed 我存的是class,所以應該不能用interface吧? 09/20 18:55
4F:→ s4300026: anumis json 完全沒聽過耶,或許是第三條路? 09/20 19:00
實際上我在找好的存檔方式,因為每日要用mail和excel交進度,
每次都要調整excel格式和寄信
覺得很懶且步驟重複
所以想說寫個小程式做協助
寫了之後覺得好用
但後來發現存class後每次有個小更新
就會造成舊的class讀檔失敗
深覺這樣不是辦法,
才想了這個辦法,但實作上遇到困難,才跑上來問,以上。
※ 編輯: s4300026 (220.134.201.145), 09/20/2018 19:25:59
5F:→ testPtt: 用一個新class包裝IMyObj介面欄位 序列化這個class 09/20 20:54
6F:→ s4300026: 這樣就可以添加新interface欄位了嗎? 09/21 07:33
7F:→ testPtt: 可能不行 沒試過 我只用過明確結構的 會變動的好像不適合 09/21 09:07
8F:→ testPtt: 不過似乎繼承IExtensibleDataObject可行 09/21 09:15
9F:推 sd016808: 如果只是新增屬性 沒有修改舊的屬性名稱 應該直接用json 09/21 13:26
10F:→ sd016808: 就可以處理了吧? 甚至也不需要那麼多版本的class 但如 09/21 13:27
11F:→ sd016808: 果每個版本之間的變化都很大 建議是實作每個版本之間的 09/21 13:27
12F:→ sd016808: 轉換 根據版本來決定new哪個版本的class 然後在一版一 09/21 13:27
13F:→ sd016808: 版的轉換到最新版 這樣一定沒問題 09/21 13:27
14F:推 totte: 用reflection 09/21 18:46
15F:推 jass970991: 我沒想過這種問題 但如果是我 我會考慮給一個dictiona 09/23 00:28
16F:→ jass970991: ry<某種enum,object> 然後這個object 才是你的class 09/23 00:28
17F:→ jass970991: 要用的時候再轉 每次更新時直接創新的class 不過這 09/23 00:28
18F:→ jass970991: 方法也不是很好 我覺得這個難題應該要先想清楚 為什 09/23 00:28
19F:→ jass970991: 麼這個class會有這麼高頻的變動還不能用generic收納這 09/23 00:28
20F:→ jass970991: 些變動 我自己是覺得有點怪 不過也可能我就真的剛好沒 09/23 00:28
21F:→ jass970991: 遇到 09/23 00:28
22F:→ s4300026: 我覺得只要更新難免會多東西吧,要想怎麼處理更新前的存 09/23 10:27
23F:→ s4300026: 檔 09/23 10:27
24F:推 jass970991: 主要是你這樣更新 一開多條branch 開發 merge時就會爆 09/23 11:12
25F:→ jass970991: 炸了 所以我才會想說到底事需求真的這樣 還是沒考慮清 09/23 11:12
26F:→ jass970991: 楚 09/23 11:12
27F:→ s4300026: 我承認是我沒有考慮清楚,原本就沒有打算寫給大程式,只 09/23 11:17
28F:→ s4300026: 想要幾個簡單的功能,沒想到想要的東西越加越多 09/23 11:17
29F:推 jass970991: 那你要做的變更的數據形態可以做整合到同一個list或di 09/23 11:19
30F:→ jass970991: c裡嗎? 這樣未來會比較好處理 09/23 11:19
31F:推 jass970991: 如果是會有function增加的問題 建議把單純的資料拉出 09/23 11:22
32F:→ jass970991: 來做成model 序列化model就好 09/23 11:22
33F:→ s4300026: 我知道了,簡言之,就是存資料,不要存方法,這樣我反 09/25 11:41
34F:→ s4300026: 而覺得我該走DB,而不是走序列化 09/25 11:41