2

Ok. I know how to use Serialization and such, but since that only applies to Objects that's been marked with Serialization attribute - how can I for example load data and use it in an application without using Serialization? Say a data file.

Or, create a datacontainer with serialization that holds files not serialized.

Methods I've used is Binary Serialization and XML Serialization. Any other ways that can load unknown data and perhaps somehow use it in C#?

4

3 回答 3

3

使用JSON.NET进行 JSON 序列化

吃掉了一切!包括匿名类型。

编辑

我知道您说“您不想要序列化”,但根据您的陈述“[...] 标记有序列化属性的对象”,我相信您没有尝试使用 JSON.NET 进行 JSON 序列化!

于 2012-07-17T15:29:45.817 回答
3

也许术语的定义是有序的;序列化是“将数据结构或对象状态转换为可以在同一或另一个计算机环境中存储和“复活”的格式的过程”。几乎任何将“易失性”内存转换为持久数据并返回的方法都是“序列化”,因此即使您推出自己的方案来做到这一点,您也是在“序列化”。

也就是说,听起来您根本不想使用 .NET 二进制序列化。这实际上是正确的想法。二进制序列化很简单,但非常依赖于代码和环境。将可序列化的类移动到不同的命名空间,或使用 Microsoft CLR 序列化文件然后尝试在 Mono 中反序列化它,可能会破坏二进制序列化。

首先,您必须能够根据文件确定您应该尝试创建的对象类型。您根本无法打开某个“随机”文件并期望能够在不知道文件中数据的结构的情况下从中获得任何有意义的东西。最简单的方法是文件告诉您,通过指定创建它的对象的类型名称(您希望在您的代码库中可用)。大多数内置序列化程序都是这样做的。文件可以告知消费者其格式的其他方式包括文件、行和/或字段标题代码(在旧标准中很常见,因为它们节省了文件大小)和扩展名/MIME 类型。

整理好之后,就可以进行反序列化了。如果文件是使用内置序列化程序序列化的,只需使用它,但如果它是较旧的格式(CSV,固定长度),那么您将不得不逐行解析文件,将其解析为代表行的对象,收集在一个代表文件的主要对象。

看看 ETL(提取-转换-加载)过程模式。这是一种模块化、可扩展的架构模式,用于获取文件并将它们转换为程序可以使用的数据:

  • 提取 - 系统的这一部分指向文件系统,或其他传入的原始数据“管道”,它的工作是打开文件,将数据提取为可以进一步操作的非常基本的对象格式,然后将那些将对象放入内存中的“队列”中以进行转换步骤。目标是尽可能快速有效地从管道中获取数据,但此时您需要对正在处理的数据有一定的了解,以便有效地封装数据以进行进一步处理;实际上将数据转换为您真正想要的格式会在稍后发生。
  • 转换 - 系统的这一部分获取提取的数据,并执行将数据放入代码库中的水合对象的逻辑。在这里,根据提取步骤中有关提取数据的文件类型的信息,您可以实例化一个表示数据模型的域对象,将原始数据分割成将作为数据成员存储的块,执行任何类型转换(您从文件中获取的数据通常是字符串格式或原始位,必须进行编组或以其他方式转换为更好地表示数据概念的数据类型),并验证新对象的内部结构是一致并符合已知的业务规则。水合的有效对象被放置在输出队列中以由加载步骤处理。
  • 加载 - 此步骤从转换步骤获取水合的有效业务对象,并将它们持久保存到系统使用的数据存储中(例如 SQL 数据库或程序的本机平面文件格式)。
于 2012-07-17T15:59:04.300 回答
0

好吧,老式的方法是使用流访问操作并读出您想要的数据。这样你就可以读/写几乎任何文件。序列化只是根据一些合同自动化这个过程。

根据您的评论,我猜您的要求是在没有合同的情况下阅读任何类型的文件。

假设您有一个原始文件,其中第一个字节指定字符串的长度,下一组字节表示字符串;

例如,5 | H | e | l | l | o

var stream = File.Open(filename);
var length = stream.ReadByte();
byte[] b = new byte[length];

stream.Read(b, 0, length);

var string = Encoding.ASCII.GetString(b);

二进制 I/O 是最原始的。 查看 MSDN 了解更多信息。

于 2012-07-17T15:40:22.127 回答