说明:Dictionary对象本身不支持序列化和反序列化,需要定义一个继承自Dictionary, IXmlSerializable类的自定义类来实现该功能。感觉完全可以把这样的类封装到C#库中,很具有通用性嘛,至今没有遇到不能用的情况的说,或许出于其他方面的考虑microsoft才没有这么做。
这里说的是字典的键值是自定义类的情况,其他情况不在讨论范围,所使用的Newtonsoft.Json.dll。
闲话少说,直接上代码。
自定义类:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace RedisTest.Test
{
[Serializable]
public class TestClass
{
public string Name = "";
public TestClass(string n)
{
Name = n;
}
public override bool Equals(object obj)
{
TestClass other = obj as TestClass;
if (other == null)
return false; if (!base.GetType().Equals(obj.GetType()))
return false; return (this.Name.Equals(other.Name));
} public override int GetHashCode()
{
return Name.GetHashCode();
} public static explicit operator TestClass(string jsonString)
{
return Newtonsoft.Json.JsonConvert.DeserializeObject<TestClass>(jsonString);
} public override string ToString()
{
return Newtonsoft.Json.JsonConvert.SerializeObject(this);
} }
}
测试代表:
using Newtonsoft.Json;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace RedisTest.Test
{
class Program
{
static void Main(string[] args)
{
Dictionary<TestClass, int> dic = new Dictionary<TestClass, int>();
TestClass c = new TestClass("c0");
dic.Add(c, );
TestClass c1 = new TestClass("c1");
dic.Add(c1, );
TestClass c2 = new TestClass("c2");
dic.Add(c2, );
TestClass c3 = new TestClass("c3");
dic.Add(c3, ); string json = JsonConvert.SerializeObject(dic, Formatting.Indented);
Console.WriteLine(json);
Dictionary<TestClass, int> dic1 = JsonConvert.DeserializeObject<Dictionary<TestClass, int>>(json); }
}
}
其中重要的是:
public static explicit operator TestClass(string jsonString)
{
return Newtonsoft.Json.JsonConvert.DeserializeObject<TestClass>(jsonString);
} public override string ToString()
{
return Newtonsoft.Json.JsonConvert.SerializeObject(this);
}