今天需要使用Json數(shù)據(jù),所以用到了Json的序列化與反序列化。首先先來說怎么序列化的:
首先添加System.Runtime.Serialization的引用
public static string ObjectToJson(object obj) { DataContractJsonSerializer ser = new DataContractJsonSerializer(obj.GetType()); using (MemoryStream ms = new MemoryStream()) { ser.WriteObject(ms, obj); return Encoding.Default.GetString(ms.ToArray()); } }
public static T JsonToObject<T>(string json) where T : class { DataContractJsonSerializer ser = new DataContractJsonSerializer(typeof(T)); using (MemoryStream ms = new MemoryStream(Encoding.Default.GetBytes(json))) { return (T)ser.ReadObject(ms); } }
程序比較簡單我就不多說了,剛開始實體類是這樣的:
[Serializable] class User { public int Age { get; set; } public string Name { get; set; } public User(string name, int age) { Age = age; Name = name; } }
然后調(diào)用:
static void Main(string[] args) { var user1 = new User("zhangsan", 18); var users = new List<User> { user1, new User("lisi", 23 ) }; var strUser1 = ObjectToJson(user1); var setUsers = ObjectToJson(users); }
加入斷點,查看json數(shù)據(jù),
居然莫名其妙出現(xiàn)了亂入的k__BackingField
從網(wǎng)上找了好多資料也沒搞明白是為啥會出現(xiàn)這個問題。想了解的可以參考下這個。不過找到了解決方案,這里記錄下:
只需要將實體類改成如下形式:
[DataContract] class User { [DataMember] public int Age { get; set; } [DataMember] public string Name { get; set; } public User(string name, int age) { Age = age; Name = name; } }
再監(jiān)視下就不會出現(xiàn)k__BackingField。Json數(shù)據(jù)轉(zhuǎn)換成實體的調(diào)用也很簡單:
static void Main(string[] args) { var user1 = new User("zhangsan", 18); var users = new List<User> { user1, new User("lisi", 23 ) }; var strUser1 = ObjectToJson(user1); var strUsers = ObjectToJson(users); var user11 = JsonToObject<User>(strUser1); var users1 = JsonToObject<List<User>>(strUsers); }
|
新聞熱點
疑難解答