序列化过程
static void Main(string[] args)
{
string FileName = Environment.GetFolderPath(Environment.SpecialFolder.Desktop) + "//test.xml";
TestSerialization test = new TestSerialization();
Stream saveFileStream = File.Create(FileName);
XmlSerializer xmlSerializer1 = new XmlSerializer(typeof(TestSerialization));
xmlSerializer1.Serialize(saveFileStream, test);
saveFileStream.Close();
//Console.ReadKey();
}
不重要。
对于自动属性
测试类
public class TestSerialization
{
public string 自动属性1 { get; set; } = "自动属性1";
public TestSerialization()
{
}
}
自动属性1
如果什么特性都不加,那么序列化的结果就是:
如果现在不想序列化自动属性1
呢?我们为其添加[NonSerialized]
特性
[NonSerialized]
public string 自动属性1 { get; set; } = "自动属性1";
可惜提示报错:
F12看NonSerialized
是sealed的
那再试一下[XmlIgnore]
特性,就可以了
[XmlIgnore]
public string 自动属性1 { get; set; } = "自动属性1";
为了更清楚的表达,写成这样会更合适,表示该特性的应用目标是属性
[property : XmlIgnore]
public string 自动属性1 { get; set; } = "自动属性1";
而不是字段,例如换成如下所示,就又无效了
[field : XmlIgnore]
public string 自动属性1 { get; set; } = "自动属性1";
对于完整的字段+属性
测试类
public class TestSerialization
{
private string _字段_属性2 = "字段+属性2";
public string 字段_属性2
{
get { return _字段_属性2; }
set { _字段_属性2 = value; }
}
public TestSerialization()
{
}
}
正常什么特性都不加,序列化的结果是这样的
如果不想序列化呢?我们先从字段_字段_属性2
入手,这里用[NonSerialized]
没有报错,但实际效果呢?没有作用,依然被序列化了。
[field : NonSerialized]
private string _字段_属性2 = "字段+属性2";
public string 字段_属性2
{
get { return _字段_属性2; }
set { _字段_属性2 = value; }
}
试试[XmlIgnore]
依然不起作用。
[field : XmlIgnore]
private string _字段_属性2 = "字段+属性2";
public string 字段_属性2
{
get { return _字段_属性2; }
set { _字段_属性2 = value; }
}
再从属性字段_属性2
入手,先用[NonSerialized]
,记得特性的应用目标从 field 换成 property,和自动属性一样,出现报错
换成[XmlIgnore]
,成功没有被序列化
private string _字段_属性2 = "字段+属性2";
[property : XmlIgnore]
public string 字段_属性2
{
get { return _字段_属性2; }
set { _字段_属性2 = value; }
}
结论
1、对于用XML进行序列化的情况,[NonSerialized]
特性不起作用,得用[XmlIgnore]
2、[XmlIgnore]
对私有字段不起作用,需作用于 自动属性 或 公有属性
即,下图这样,才能不序列化
哈哈哈哈,研究了半天,MSDN其实都写了,学习还是得细心,仔细啊