详解.NET Core 3.0 里新的JSON API(2)

首先需要告诉writer把它的内容flush给buffer,使用这个buffer我们可以获得 writer 的输出,这样的话就会得到一个byte数组,然后把这个 byte 数组转化为字符串,这样就可以在控制台显示它了:  

详解.NET Core 3.0 里新的JSON API

运行一下看看效果:

没啥太大的问题,就是格式不好看。

对输出进行格式化  

.NET Core 提供了一个 JsonWrite r Options 类,它可以对Writer进行一些设置。  

详解.NET Core 3.0 里新的JSON API

这里对输出进行了缩进,最后把这个options传递给Utf 8JsonWriter 的构造函数即可。  

再次运行:

详解.NET Core 3.0 里新的JSON API

现在好看多了。

JsonSerializer  

前面几节的内容可能稍微有点底层,我们大部分时候可能只需要对 C# 的类进行串行化或者将 JSON 数据反串行化成 C# 类,在 .NET Core  3.0 里面,我们可以使用 JsonSerializer 这个类来做这些事情。  

例子:

还是使用之前用到的 json 数据:  

详解.NET Core 3.0 里新的JSON API

然后我们需要建建立两个类,对应这个文件:

详解.NET Core 3.0 里新的JSON API

反串行化  

可以使用Json Serializer 类的 Deserialize() 方法对 json 数据反串行化。这个方法支持三种类型的输入参数,分别是:  

JSON数据的字符串

Utf 8JsonReader  

Read OnlySpan<byte> ,它里面包含 JSON 数据  

为了简单一点,我直接把json文件读取成字符串,然后传给 Deserialize 方法:  

详解.NET Core 3.0 里新的JSON API

然后我试图打印出反串行化之后的一些属性数据。但是这不会成功。因为JSON文件里面数据的大小写命名规范使用的是 camel casing (简单理解为首字母是小写的),而默认情况下 Deserializer 会寻找 Pascal casing 这种规范(简单理解为每个单词的首字母都是大写的)的属性名。  

格式化  

为解决这个问题,就需要使用 JsonSerializerOptions 类:  

详解.NET Core 3.0 里新的JSON API

建立该类的一个实例,设置 Property NamingPolicy 为 CamelCase ,然后把这个实例传递给 Deserialize 方法的第二个参数。  

运行看结果 :  

这次就没有问题了。

串行化  

Json Serializer 也支持串行化,也就是把C#数据转化为 JSON 数据:  

这里使用了相同的 options 。  

运行结果:

如果想让输出结果更好看一些,可以在 JsonSerializerOptions 里面进行相应的设置:  

详解.NET Core 3.0 里新的JSON API

这次输出结果为:

详解.NET Core 3.0 里新的JSON API

总结  

总结一下 .NET Core 3.0 新的JSON  API :  

Utf 8JsonReader -  读操作,快速,低级  

Utf 8JsonWriter -  写操作,快速,低级  

JsonDocument -  基于DOM,快速  

Json Seriliazer -  串行化 / 反串行化,快速  

另外 JSON .NET  仍然被支持。  

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wygwjw.html