其实最初笔者仅仅是为了研究Xml的c#读取,但不知不觉就弄明白为什么反序列化为什么不能实现读取的原因
- 一般网上对于Xml的读取有三种实现,三种方法分别是Xml的document读取,一个是render输入输出流,Linq,初见我以为是四种,包括反序列化进行直接赋值,但实际上反序列化是涵盖输入输出流里面的,这里不懂可以去看看其他关于xml读取的blog,我这里就直接抛出我的代码
public class DataAnalysis:MonoBehaviour
{
public LoginList m_Logininfo;
/// <summary>
/// 用于解析xml的方法
/// </typeparam>
/// <param name="path">xml文件的路径</param>
/// <param name="ms">用于接受xml文件解析的结果</param>
public void LoadXml<T>(string path, ref T ms) where T : class
{
try
{
//通过流根据路径去读取文件
using (TextReader reader = new StreamReader(path))
{
var serializer = new XmlSerializer(typeof(T));
var item = (T)serializer.Deserialize(reader);
if (item != null)
{
ms = item;
}
}
}
catch (Exception ex)
{
//用于捕捉异常避免解析过程中出现错误导致程序死掉
//将错误打印出来
Debug.LogError(ex.Message);
}
}
//用于接收Xml数据结构的定义规则
/*
* 用于接收数据的类上面必须接上属性标签否则属性不会被识别
* 用于接收赋值的必须定义为属性,不可为变量否则也是无法被识别的
* 定义的结构要与xml相对应
*/
[XmlRoot("data")]
public class LoginList
{
[XmlElement("say")]
public List<Login> Ins { set; get; }
}
void Start()
{
string path = Application.dataPath + "\\game.xml";
LoadXml(path, ref m_Logininfo);
Debug.Log( m_Logininfo.Ins[0].name);
}
}
当然这里正常来说,是没有问题的,只不过我这里再加上一些其他代码,这里就血崩了。
public class Login
{
[XmlAttribute(AttributeName = "index")]
public string name { set; get; }
[XmlAttribute(AttributeName = "next")]
public string sex { set; get; }
[XmlAttribute(AttributeName = "iswhat")]
public string id { set; get; }
public realquetion asss;
public realquetion bssss;
public realquetion csss;
public realquetion dsss;
}
其实原因很简单,我们需要了解什么是序列化,大概是将某个类给变成某种类型对象,像这里实际上也就是将Login这个类序列化成一个xml对象(实际并不是xml),然后将反序列化的xml进行赋值,当缺失某一部分,里面有嵌套的非属性字段,序列化就不成功,所以运行时会报错
![E$N_PKB}A]E4APB86%`D7~X.png](https://upload-images.jianshu.io/upload_images/13871785-79e944463202b97e.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
具体我就讲这么多,接下来我将替换掉序列化读取这个蠢方法,之后采用linq来实现,当然这里面可能内部实现依然涉及序列化大坑,不过也是下一节关注事情了,那么晚安