c#_序列化与反序列化的应用
Posted x1angzeeD.
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c#_序列化与反序列化的应用相关的知识,希望对你有一定的参考价值。
本篇博客不讲理论!
如果想看理论这里附上三篇博客:
Json:https://blog.csdn.net/qq_48705696/article/details/116536267?spm=1001.2014.3001.5501
XML:https://blog.csdn.net/qq_48705696/article/details/115301270?spm=1001.2014.3001.5501
序列化与反序列化:https://www.cnblogs.com/yzenet/p/3622833.html
直接上干货!
1、将需要保存的东西(比如类、结构)前加上可序列化的标识[Serializable],像下面这样:
2、读取与保存的源代码:
/// </summary>
/// <param name="path">要保存的路径,如:C:\\a.obj,a.obj是自己的取的文件名和扩展名,可以随便取,没有的路径都会自动生成</param>
/// 注:路径可以随便写,会自动生成:如:C:\\A\\B\\C\\test.obj 程序会自动生成A,B,C目录
/// 注:保存文件后缀推荐使用 .json / .xml
/// <param name="obj">要保存的对象,object:所有类的父基类</param>
public static void SaveObject(string path, object obj)
{
IFormatter formatter = new BinaryFormatter();
try
{
Stream stream = new FileStream(@"" + path, FileMode.OpenOrCreate, FileAccess.Write, FileShare.None);
formatter.Serialize(stream, obj);
stream.Close();
Console.WriteLine("[" + path + "]文件保存成功...");
//将对象写入到本地
}
catch (Exception)
{
Console.WriteLine("[" + path + "]文件保存失败...");
}
}
/// </summary>
/// 注:读取时像这样使用 Person p1 = ReadObject<Person>(@"路径");
/// <typeparam name="T">返回指定的类型</typeparam>
/// <param name="path">文件的路径</param>
/// <returns></returns>
public static T ReadObject<T>(string path)
{
try
{
IFormatter formatter = new BinaryFormatter();
Stream stream = new FileStream(@"" + path, FileMode.Open, FileAccess.Read, FileShare.None);
T myObj = (T)formatter.Deserialize(stream);
stream.Close();
return myObj;
}
catch (Exception)
{
if (File.Exists(path))//如果文件不存在,创建文件
{
//...
}
else
{
File.Create(path).Dispose();
}
}
T t = default(T);
return t;
}
以上是关于c#_序列化与反序列化的应用的主要内容,如果未能解决你的问题,请参考以下文章
BigDataJava基础_ObjectOutputStream与ObjectInputStream实现序列化与反序列化