System.Memory.Data 10.0.0-rc.2.25502.107

About

System.Memory.Data introduces the BinaryData type, a lightweight abstraction for a byte payload. It makes it easy to convert between string, bytes, and stream.

This abstraction can simplify the API surface by exposing a single type instead of numerous overloads or properties. The BinaryData type handles data ownership efficiently, wrapping passed-in bytes when using byte[] or ReadOnlyMemory<byte> constructors or methods, and managing data as bytes when dealing with streams, strings, or rich model types serialized as JSON.

Key Features

  • Lightweight abstraction for byte payload via BinaryData type.
  • Convenient helper methods for common conversions among string, bytes, and stream.
  • Efficient data ownership handling.

How to Use

To/From String:

var data = new BinaryData("some data");

// ToString will decode the bytes using UTF-8
Console.WriteLine(data.ToString()); // prints "some data"

To/From Bytes:

byte[] bytes = Encoding.UTF8.GetBytes("some data");

// Create BinaryData using a constructor ...
BinaryData data = new BinaryData(bytes);

// Or using a static factory method.
data = BinaryData.FromBytes(bytes);

// There is an implicit cast defined for ReadOnlyMemory<byte>
ReadOnlyMemory<byte> rom = data;

// There is also an implicit cast defined for ReadOnlySpan<byte>
ReadOnlySpan<byte> ros = data;

// there is also a ToMemory method that gives access to the ReadOnlyMemory.
rom = data.ToMemory();

// and a ToArray method that converts into a byte array.
byte[] array = data.ToArray();

To/From stream:

var bytes = Encoding.UTF8.GetBytes("some data");
Stream stream = new MemoryStream(bytes);
var data = BinaryData.FromStream(stream);

// Calling ToStream will give back a stream that is backed by ReadOnlyMemory, so it is not writable.
stream = data.ToStream();
Console.WriteLine(stream.CanWrite); // prints false

BinaryData also can be used to integrate with ObjectSerializer. By default, the JsonObjectSerializer will be used, but any serializer deriving from ObjectSerializer can be used.

var model = new CustomModel
{
    A = "some text",
    B = 5,
    C = true
};

var data = BinaryData.FromObjectAsJson(model);
model = data.ToObjectFromJson<CustomModel>();

Main Types

The main types provided by this library are:

  • System.BinaryData

Additional Documentation

Feedback & Contributing

System.Memory.Data is released as open source under the MIT license. Bug reports and contributions are welcome at the GitHub repository.

Showing the top 20 packages that depend on System.Memory.Data.

Packages Downloads
Azure.Core
This is the implementation of the Azure Client Pipeline
122
Azure.Core
This is the implementation of the Azure Client Pipeline
117
Azure.Core
This is the implementation of the Azure Client Pipeline
109
Azure.Core
This is the implementation of the Azure Client Pipeline
102
Azure.Core
This is the implementation of the Azure Client Pipeline
98
Azure.Core
This is the implementation of the Azure Client Pipeline
95
Azure.Core
This is the implementation of the Azure Client Pipeline
93
Azure.Core
This is the implementation of the Azure Client Pipeline
92
Azure.Core
This is the implementation of the Azure Client Pipeline
91
Azure.Core
This is the implementation of the Azure Client Pipeline
90
Azure.Core
This is the implementation of the Azure Client Pipeline
89
Azure.Core
This is the implementation of the Azure Client Pipeline
88
Azure.Core
This is the implementation of the Azure Client Pipeline
86
Azure.Core
This is the implementation of the Azure Client Pipeline
81
System.ClientModel
Contains building blocks for clients that call cloud services.
80

.NET Framework 4.6.2

.NET 8.0

.NET 9.0

.NET 10.0

  • No dependencies.

.NET Standard 2.0

Version Downloads Last updated
10.0.0-rc.2.25502.107 3 10/16/2025
10.0.0-rc.1.25451.107 12 9/11/2025
10.0.0-preview.7.25380.108 10 8/14/2025
10.0.0-preview.6.25358.103 14 7/20/2025
10.0.0-preview.5.25277.114 13 6/8/2025
10.0.0-preview.4.25258.110 25 5/15/2025
10.0.0-preview.3.25171.5 25 4/11/2025
10.0.0-preview.2.25163.2 27 3/26/2025
10.0.0-preview.1.25080.5 32 2/27/2025
9.0.10 2 10/17/2025
9.0.9 14 9/11/2025
9.0.8 15 8/6/2025
9.0.7 21 7/14/2025
9.0.6 19 6/13/2025
9.0.5 31 5/16/2025
9.0.4 35 4/11/2025
9.0.3 38 3/13/2025
9.0.2 40 2/14/2025
9.0.1 53 1/28/2025
9.0.0 50 11/14/2024
9.0.0-rc.2.24473.5 50 10/22/2024
9.0.0-rc.1.24431.7 50 9/12/2024
9.0.0-preview.7.24405.7 58 8/19/2024
9.0.0-preview.6.24327.7 61 7/10/2024
9.0.0-preview.5.24306.7 60 6/20/2024
9.0.0-preview.4.24266.19 69 6/5/2024
9.0.0-preview.3.24172.9 56 5/7/2024
9.0.0-preview.2.24128.5 61 3/18/2024
9.0.0-preview.1.24080.9 56 2/28/2024
8.0.1 60 10/26/2024
8.0.0 70 11/16/2023
8.0.0-rc.2.23479.6 81 10/23/2023
8.0.0-rc.1.23419.4 69 9/15/2023
8.0.0-preview.7.23375.6 76 8/22/2023
8.0.0-preview.6.23329.7 70 8/4/2023
8.0.0-preview.5.23280.8 69 8/2/2023
8.0.0-preview.4.23259.5 70 5/20/2023
8.0.0-preview.3.23174.8 63 5/20/2023
8.0.0-preview.2.23128.3 70 5/20/2023
8.0.0-preview.1.23110.8 87 2/26/2023
7.0.0 76 12/7/2022
7.0.0-rc.2.22472.3 76 12/7/2022
7.0.0-rc.1.22426.10 77 9/15/2022
7.0.0-preview.7.22375.6 74 9/7/2022
7.0.0-preview.6.22324.4 67 9/19/2022
7.0.0-preview.5.22301.12 77 7/1/2022
7.0.0-preview.4.22229.4 74 7/1/2022
7.0.0-preview.3.22175.4 91 7/1/2022
7.0.0-preview.2.22152.2 75 7/1/2022
7.0.0-preview.1.22076.8 82 7/1/2022
6.0.2-mauipre.1.22102.15 77 7/1/2022
6.0.2-mauipre.1.22054.8 69 7/1/2022
6.0.1 56 11/14/2024
6.0.0 100 7/1/2022
6.0.0-rc.2.21480.5 71 7/1/2022
6.0.0-rc.1.21451.13 75 7/1/2022
6.0.0-preview.7.21377.19 70 7/1/2022
6.0.0-preview.6.21352.12 71 7/1/2022
6.0.0-preview.5.21301.5 73 7/1/2022
6.0.0-preview.4.21253.7 74 7/1/2022
6.0.0-preview.3.21201.4 75 7/1/2022
6.0.0-preview.2.21154.6 76 7/1/2022
6.0.0-preview.1.21102.12 78 7/1/2022
1.0.2 82 7/1/2022
1.0.1 93 7/1/2022
1.0.0 84 7/1/2022
1.0.0-beta.2 88 7/1/2022
1.0.0-beta.1 85 7/1/2022