SerializIt 0.6.13
dotnet add package SerializIt --version 0.6.13
NuGet\Install-Package SerializIt -Version 0.6.13
<PackageReference Include="SerializIt" Version="0.6.13" />
paket add SerializIt --version 0.6.13
#r "nuget: SerializIt, 0.6.13"
// Install SerializIt as a Cake Addin #addin nuget:?package=SerializIt&version=0.6.13 // Install SerializIt as a Cake Tool #tool nuget:?package=SerializIt&version=0.6.13
<p align="center"> <img src ="https://raw.githubusercontent.com/KhaosCoders/SerializIt/master/Art/Icon.png" width=200 /> </p>
SerializIt
A super fast serializer using Roslyn SourceGenerators instead of reflection
Only supports serialization, no deserialization!
Supported Serializers
- JSON
- YAML
- (basic) XML
Installation
You can find this package on nuget.org.
Install SerializIt
using Package Manager Console:
Install-Package SerializIt
Or a terminal:
dotnet add package SerializIt
Usage
Create a model you want to serialize.
Then create a partial
serialization context like this
using SerializIt;
using Samples.Model;
namespace Samples
{
[Serializer(ESerializers.Yaml)]
[YamlOptions(indentChars: " ")]
[SerializeType(typeof(RootElement))]
[SerializeType(typeof(Container))]
[SerializeType(typeof(Info))]
internal partial class YamlContext { }
}
This context will be augmented with a serializer for each defined type.
Call the SerializeDocument
(or SerializeElement
) method to serialize an object instance.
// var root = new RootElement();
var serializeIt = new YamlContext();
string text = serializeIt.RootElement.SerializeDocument(root);
Take the Samples project in this repo as an example.
Serialization should be super fast!
Benchmarks
This Benchmark compares SerializIt
JSON, YAML and XML serialization with other common libraries, like Tinyhand, System.Text.Json, YamlDotNet and System.Xml.Serialization. This benchmark was run on my HP Notebook (16GB Ram, Intel i7-8565U, SSD).
Method | Mean | Error | StdDev | Median | Gen 0 | Gen 1 | Gen 2 | Allocated |
---|---|---|---|---|---|---|---|---|
TinyhandJson | 428.7 us | 17.17 us | 48.98 us | 398.2 us | 49.8047 | 9.7656 | - | 207 KB |
SystemTextJsonSG | 221.4 us | 3.41 us | 3.50 us | 220.3 us | 38.3301 | 38.3301 | 38.3301 | 121 KB |
SystemTextFormattedJsonSG | 285.7 us | 3.32 us | 2.77 us | 285.2 us | 66.4063 | 66.4063 | 66.4063 | 208 KB |
SerializItJson | 194.2 us | 0.70 us | 0.58 us | 194.4 us | 41.5039 | 41.5039 | 41.5039 | 130 KB |
SerializItFormattedJson | 308.7 us | 2.59 us | 2.02 us | 309.5 us | 52.2461 | 52.2461 | 52.2461 | 164 KB |
YamlDotNet | 13,335.0 us | 111.03 us | 159.23 us | 13,327.2 us | 1125.0000 | 218.7500 | 31.2500 | 4,873 KB |
SerializItYaml | 206.9 us | 2.53 us | 2.25 us | 206.9 us | 41.5039 | 41.5039 | 41.5039 | 130 KB |
XmlSerializer | 628.0 us | 7.36 us | 6.89 us | 626.4 us | 54.6875 | 54.6875 | 54.6875 | 395 KB |
SerializItXml | 175.0 us | 2.55 us | 2.26 us | 174.3 us | 65.6738 | 65.6738 | 65.6738 | 207 KB |
Conclusion
SerializIt
is fast. But, if you want to serialize to and from JSON your better of with the Source Generators in System.Text.Json
. When you're after YAML or XML serialization however, SerializIt
is your best option. It delivers much faster serialization to these formats, than the common libraries this benchmark was performed with.
Remarks
SerializIt
does only serialize object. There is no de-serialization for now. So if you need to de-serialize some YAML or XML you're again better of with the mentioned libraries, as they offer de-serialization, too. Moreover, the XML serializer comming with SerializIt
is in alpha stage, at best. A lot of work needs to be done, to make it a helpfull serializer.
Features
This serializer supports the following features:
- Formats: JSON, YAML, (basic) XML
- PrettyPrint (JSON / XML): On/Off
- Custom Indentation - Defaults to Tabs
- Can skip defined properties
- Can skip properties with default value
- Can order properties
Pending improvements
[ ] Value Converters (serialize complex data types, like GUID
or BitInteger
)
[ ] Custom serializers (support custom formats)
[ ] Serializer specific member options (like CDATA for XML or Inline for Yaml & Json)
[ ] XML Namespaces
[ ] XML Attributes
Support this ❤️
If you like my work, please support this project!
Donate via PayPal
or become a Sponsor on GitHub
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
0.6.13 | 182 | 6/4/2023 |
0.6.12 | 144 | 6/4/2023 |
0.6.11 | 138 | 6/4/2023 |
0.6.10 | 143 | 6/4/2023 |
0.6.9 | 135 | 6/4/2023 |
0.6.8 | 139 | 6/4/2023 |
0.6.6 | 140 | 6/4/2023 |
0.6.5 | 137 | 6/4/2023 |
0.6.4 | 146 | 6/4/2023 |
0.6.3 | 137 | 6/4/2023 |
0.6.2 | 151 | 6/4/2023 |
0.6.1 | 137 | 6/4/2023 |
0.6.0 | 139 | 6/4/2023 |
0.5.7 | 144 | 6/2/2023 |
0.5.6 | 142 | 6/2/2023 |
0.5.5 | 149 | 6/2/2023 |
0.5.4 | 151 | 5/6/2023 |
0.5.3 | 141 | 5/6/2023 |
0.5.2 | 144 | 5/6/2023 |
0.5.1 | 144 | 5/6/2023 |
0.5.0 | 152 | 5/5/2023 |
0.4.0 | 185 | 4/21/2023 |