欢迎收看本期的《老周吹牛》节目,由于剧组严重缺钱,故本节目无视频无声音。好,先看下面一个类声明。

    [DataContract]
public class DemoObject
{
[DataMember]
public double Part1 { get; set; }
[DataMember]
public int Part2 { get; set; }
[DataMember]
public byte Part3 { get; set; }
[DataMember]
public string Part4 { get; set; }
}

这个类是老周随便瞎写的,没有特别内涵,只是用来做做实验而已。注意类型上应用的attribute,它被定义为数据协定。

下面是重点,对这个类的实例进行序列化,所以,我们先得new一个实例。

            DemoObject obj = new DemoObject
{
Part1 = 33.0065d,
Part2 = ,
Part3 = ,
Part4 = "kill dog"
};

然后,可以序列化了。

            DataContractSerializerSettings settings = new DataContractSerializerSettings
{
MaxItemsInObjectGraph = 3 }; DataContractSerializer szr = new DataContractSerializer(obj.GetType(), settings);
szr.WriteObject(stream, obj);

注意,在序列化前,我创建了一个DataContractSerializerSettings对象,并把一个名为 MaxItemsInObjectGraph 的属性设置为3,这是啥含义呢,别急,咱们看看这段代码在运行时会发生什么意外。

从上面的高清图中大家看到了,它说 MaxItemsInObjectGraph = 3,这尺码太小了,穿不上。

MaxItemsInObjectGraph 值用来设置实例对象在序列化的时候,能够处理数据项的最大值

那么,DemoObject 类在序列化时,到底会有多少个数据项呢,怎么计算的呢。

来,我们一层一层地剥皮。

第一层:DemoObject对象本身,算1个。

第二层:它有四个属性,而且每个属性的类型都是基础类型(string、int等),基础类型都视为单个数据项,所以此层有4项数据。

好,两层加起来就是 = 5,也就是说,要序列化 DemoObject 类对象,序列化程序需要处理5个数据项,因此,3太小了,咱们换个大号的,把它改为5。

            DataContractSerializerSettings settings = new DataContractSerializerSettings
{
MaxItemsInObjectGraph =
};

这么一改,就可以正常序列化了。

如果还不过瘾,咱们继续探讨。

来,看看下面这个类。

    [DataContract]
public class Something
{
[DataMember]
public List<double> Items { get; private set; } public Something()
{
Items = new List<double>();
}
}

你猜猜,它在序列化时要处理多少项数据?

好,咱们设置最大值为3,试试看。

            Something obj = new Something();
obj.Items.Add(0.001d);
obj.Items.Add(-99.99d); DataContractSerializerSettings settings = new DataContractSerializerSettings
{
MaxItemsInObjectGraph =
}; DataContractSerializer sz = new DataContractSerializer(obj.GetType(), settings);
sz.WriteObject(stream, obj);

运行上面代码,你会收到异常信息,这说明,3个数据项是不够的。

那么,现在咱们来数一下:

第一层,Something 类实例自身算是1个对象。

第二层,Something类中 有个Items属性,它是一个List<T>对象,算是1个。

第三层,list中有两个double值,算是2个对象。

最后,序列化要处理的对象数 = 1 + 1 + 2 = 4。

所以,把上面代码改一下,改为4,或者大于4都行,因为 MaxItemsInObjectGraph 设置的是取大项数,你设100也行。

            DataContractSerializerSettings settings = new DataContractSerializerSettings
{
MaxItemsInObjectGraph =
};

这样就可以正常序列化了。序列化生成以下XML。

<Something xmlns="……" xmlns:i="http://www.w3.org/2001/XMLSchema-instance">
<Items xmlns:a="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
<a:double>0.001</a:double>
<a:double>-99.99</a:double>
</Items>
</Something>

下面咱们来个变态级别的,你能数出来吗?

    [DataContract]
public class Employee
{
[DataMember]
public string Name { get; set; }
[DataMember]
public int Age { get; set; }
} [DataContract]
public class PartMent
{
[DataMember]
public string PartName { get; set; }
[DataMember]
public Employee Manager { get; set; }
[DataMember]
public List<Employee> Members { get; set; }
}

注意,这两个数据协有关联,PartMent实例会引用N个Employee 实例。而且,PartMent 中有个list类型的属性,所以,序列化的数据项数量是变动的,因为list中可以添加X个对象。

我们先把可以确定的对象数算出来,对于可变的,我们就用一个x来指代。

1,PartMent 自身算1个。

2,PartName 属性是字符串类型,算1个。

3、Manager 属性是Employee类型。Employee类好计算吧,类实例本身1个,Name 和 Age 属性都是基础类型,共2个,加起来即一个Employee实例会包含 3 个数据项。

4、Members 属性是个List<T>,list 实例自身算 1 个,而里面每个Employee实例,刚刚算过,是3个,如果有x个实例,就是 3 × x 个数据项, 合计为 1 + 3x 个数据项。

总结上面的分析,得出一个通用公式: n = 1+1+3+(1+3x) ,再整理一下就是:n = 6 + 3x。

好,来个代码演示。

            PartMent pmt = new PartMent();
pmt.PartName = "人渣部门";
pmt.Manager = new Employee { Name = "老鬼", Age = };
// 1 + 1 + (1 + 2) = 5 List<Employee> emps = new List<Employee>();
emps.Add(new Employee { Name = "小李", Age = });
emps.Add(new Employee { Name = "小刘", Age = });
emps.Add(new Employee { Name = "小杜", Age = });
pmt.Members = emps;
// (3 * 3) + 1 = 10 DataContractSerializerSettings settings = new DataContractSerializerSettings
{
MaxItemsInObjectGraph =
}; DataContractSerializer sz = new DataContractSerializer(pmt.GetType(), settings);
sz.WriteObject(stream, pmt);

上面代码中,在 list 里面放了 3 个 Employee 实例,套上面得到的公式 6+3*3 = 15,所以,这个实例序列化后会处理 15 个数据项,生成的XML如下:

<PartMent xmlns="……" xmlns:i="http://www.w3.org/2001/XMLSchema-instance">
<Manager>
<Age>55</Age>
<Name>老鬼</Name>
</Manager>
<Members>
<Employee>
<Age>25</Age>
<Name>小李</Name>
</Employee>
<Employee>
<Age>40</Age>
<Name>小刘</Name>
</Employee>
<Employee>
<Age>37</Age>
<Name>小杜</Name>
</Employee>
</Members>
<PartName>人渣部门</PartName>
</PartMent>

怎么样,刺激吧。

当然了,我只是为了演示,就设置为15个,其实,最大值一般不会这么小,设置几百个也可以。序列化选项之所以会有这个最大值的限制数值,是为了防止一些不良青年搞恶意破坏,比如,如果某个客户端要向服务器提交数据,数据内容自然是要先序列化,然后才能通过网络发送,尤其像web服务调用这种情况。你想想,如果不设置个限制值,别有用心的人,可以故意地弄一个特大对象来攻击服务器。

OK,今天的吹牛节目就此结束了,下次有空再见。

【.net 深呼吸】设置序列化中的最大数据量的更多相关文章

  1. 【MySQL】MySQL中针对大数据量常用技术_创建索引+缓存配置+分库分表+子查询优化(转载)

    原文地址:http://blog.csdn.net/zwan0518/article/details/11972853 目录(?)[-] 一查询优化 1创建索引 2缓存的配置 3slow_query_ ...

  2. asp.net中绘制大数据量的可交互的图表

    在一个asp.net项目中要用到能绘制大数据量信息的图表,并且是可交互的(放大.缩小.导出.打印.实时数据),能够绘制多种图形. 为此进行了多方调查预研工作,预研过微软的MsChart图表组件.基于j ...

  3. BloomFilter中保存的数据量

    结果 /** * @author WeiJiQian * BF_CARDINAL_THRESHOLD BF_FALSE_POSITIVE_RATE 保存的数据量 * 100,0000 0.01 391 ...

  4. 【.net 深呼吸】序列化中的“引用保留”

    假设 K 类中有两个属性/字段的类型相同,并且它们引用的是同一个对象实例,在序列化的默认处理中,会为每个引用单独生成数据. 看看下面两个类. [DataContract] public class 帅 ...

  5. MySQL设置表中字段的数据唯一性

    mysql设置数据库表里的某个字段的数据是唯一的 ALTER TABLE 表名 ADD unique(`表中的字段`)

  6. Kendo UI中TreeView 放入tabstrip中,大数据量时超过边框的解决方案。

    参考http://www.kendoui.com/forums/ui/tabstrip/tabstip-with-treeview-treeview-breaking-out-of-tabstrip. ...

  7. MS Sql Server 查询数据库中所有表数据量

    方法一: SELECT a.name,b.rows FROM sysobjects a INNER JOIN sysindexes b ON a.id=b.id ,) AND a.Type='u' O ...

  8. 关于MySQL中查询大数据量的情况下分页limit的性能优化

    https://blog.csdn.net/weixin_37848710/article/details/80772725

  9. 采用Kettle分页处理大数据量抽取任务

    作者:Grey 原文地址: http://greyzeng.com/2016/10/31/big-data-etl/ 需求: 将Oracle数据库中某张表历史数据导入MySQL的一张表里面. 源表(O ...

随机推荐

  1. Redis数据库

    Redis是k-v型数据库的典范,设计思想及数据结构实现都值得学习. 1.数据类型 value支持五种数据类型:1.字符串(strings)2.字符串列表(lists)3.字符串集合(sets)4.有 ...

  2. Nhibernate的Session管理

    参考:http://www.cnblogs.com/renrenqq/archive/2006/08/04/467688.html 但这个方法还不能解决Session缓存问题,由于创建Session需 ...

  3. JavaScript自定义媒体播放器

    使用<audio>和<video>元素的play()和pause()方法,可以手工控制媒体文件的播放.组合使用属性.事件和这两个方法,很容易创建一个自定义的媒体播放器,如下面的 ...

  4. 算法与数据结构(十七) 基数排序(Swift 3.0版)

    前面几篇博客我们已经陆陆续续的为大家介绍了7种排序方式,今天博客的主题依然与排序算法相关.今天这篇博客就来聊聊基数排序,基数排序算法是不稳定的排序算法,在排序数字较小的情况下,基数排序算法的效率还是比 ...

  5. 【NLP】蓦然回首:谈谈学习模型的评估系列文章(一)

    统计角度窥视模型概念 作者:白宁超 2016年7月18日17:18:43 摘要:写本文的初衷源于基于HMM模型序列标注的一个实验,实验完成之后,迫切想知道采用的序列标注模型的好坏,有哪些指标可以度量. ...

  6. windows环境redis主从安装部署

    准备工作 下载windows环境redis,我下载的是2.4.5,解压,拷贝一主(master)两从(slaveof).主机端口使用6379,两从的端口分别为6380和6381, 我本地索性用6379 ...

  7. 数据的双向绑定 Angular JS

    接触AngularJS许了,时常问自己一些问题,如果是我实现它,会在哪些方面选择跟它相同的道路,哪些方面不同.为此,记录了一些思考,给自己回顾,也供他人参考. 初步大致有以下几个方面: 数据双向绑定 ...

  8. go语言:多个[]byte数组合并成一个[]byte

    场景:在开发中,要将多个[]byte数组合并成一个[]byte,初步实现思路如下: 1.获取多个[]byte长度 2.构造一个二维码数组 3.循环将[]byte拷贝到二维数组中 package gst ...

  9. AspNetPager分页控件样式的使用

    分页是Web应用程序中最常用到的功能之一,AspNetPager  简单实用,应用到项目后台中,棒极了! 自定义样式: <style type="text/css"> ...

  10. JS or C#?不存在的脚本之争

    前言: 又来到了周末,小匹夫也终于有了喘口气写写博客的时间和精力.话说周五的下午,小匹夫偶然间晃了一眼蛮牛的QQ群,又看到了一个Unity3D开发中老生长谈的问题,“我的开发语言究竟是选择JavaSc ...