刚写了前面一个post,在csdn上就看到了这个问题:如何将界面保存,比如存入数据库或XML
首先想到的当然是.NET的序列化机制,不过可惜的是打开MSDN一看,发现继承于System.Windows.Forms.Control的子类没有一个带有[Serializable]标签,根本行不通。
还有一个办法是,让自己的Form继承ISerializable接口,自己控制序列化的方式。但是问题是需要序列化的内容太多,编码冗繁且易出错。
联想到.NET超酷的反射机制,和上个post里写的技巧,我现在的想法是利用反射机制得到对象的所有字段(不是属性,属性本质上还是方法)和字段的值,提取成一个列表,对象内对象通过同样方法处理,这样的递归调用是不是就可以把所有的对象变成由基元类型(比如int这样的类型)组成的集合?从而就可以容易的保存到XML这样的文件或者数据库里?
我想FCL内置的BinaryFormatter和SoapFormatter的工作原理大致也是如此。只不过他们要求所有的类型都带有[Serializable]标签,否则就弹出异常。而事实上大部分不带有这个标签的类型往往也可以序列化的,只是开发者没有愿意加上而已。
FCL设计者的这种谨慎的做法使得FCL内置的带有[Serializable]标签的类型在序列化前和反序列化之后完全是一样的,而其他的类型则不允许被序列化。揣测其原因,比如Socket这样的类,序列化它往往是没有意义的,因为它和其环境密切相关。然而,其大部分属性还是支持符合实际含义的序列化,比如其构造函数的三个参数对应的内部的字段,这就给我们自己设计个“超级序列化工具”提供了可能性。