System.Memory.Data 8.0.1

Prefix Reserved
There is a newer version of this package available.
See the version list below for details.
dotnet add package System.Memory.Data --version 8.0.1                
NuGet\Install-Package System.Memory.Data -Version 8.0.1                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="System.Memory.Data" Version="8.0.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add System.Memory.Data --version 8.0.1                
#r "nuget: System.Memory.Data, 8.0.1"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install System.Memory.Data as a Cake Addin
#addin nuget:?package=System.Memory.Data&version=8.0.1

// Install System.Memory.Data as a Cake Tool
#tool nuget:?package=System.Memory.Data&version=8.0.1                

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.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 is compatible.  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 is compatible.  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 is compatible.  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. 
.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 is compatible.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (144)

Showing the top 5 NuGet packages that depend on System.Memory.Data:

Package Downloads
Azure.Core

This is the implementation of the Azure Client Pipeline

Microsoft.Azure.WebJobs.Core

This package provides the core Types and Attribute definitions for the WebJobs SDK. For more information, please visit https://go.microsoft.com/fwlink/?linkid=2279708.

Microsoft.Azure.WebJobs

This package contains the runtime host components of the WebJobs SDK. For more information, please visit https://go.microsoft.com/fwlink/?linkid=2279708.

Azure.Messaging.ServiceBus

Azure Service Bus is a fully managed enterprise integration message broker. Service Bus can decouple applications and services. Service Bus offers a reliable and secure platform for asynchronous transfer of data and state. This client library allows for both sending and receiving messages using Azure Service Bus. For more information about Service Bus, see https://learn.microsoft.com/azure/service-bus-messaging/service-bus-messaging-overview

Azure.Core.Amqp

This library contains AMQP model types used by Azure libraries.

GitHub repositories (2)

Showing the top 2 popular GitHub repositories that depend on System.Memory.Data:

Repository Stars
microsoft/semantic-kernel
Integrate cutting-edge LLM technology quickly and easily into your apps
dotnet/orleans
Cloud Native application framework for .NET
Version Downloads Last updated
9.0.0 43,755 11/12/2024
9.0.0-rc.2.24473.5 6,869 10/8/2024
9.0.0-rc.1.24431.7 8,047 9/10/2024
9.0.0-preview.7.24405.7 1,377 8/13/2024
9.0.0-preview.6.24327.7 1,316 7/9/2024
9.0.0-preview.5.24306.7 2,238 6/11/2024
9.0.0-preview.4.24266.19 906 5/21/2024
9.0.0-preview.3.24172.9 1,058 4/11/2024
9.0.0-preview.2.24128.5 1,893 3/12/2024
9.0.0-preview.1.24080.9 990 2/13/2024
8.0.1 367,675 10/8/2024
8.0.0 4,309,102 11/14/2023
8.0.0-rc.2.23479.6 4,675 10/10/2023
8.0.0-rc.1.23419.4 4,999 9/12/2023
8.0.0-preview.7.23375.6 5,226 8/8/2023
8.0.0-preview.6.23329.7 3,665 7/11/2023
8.0.0-preview.5.23280.8 1,344 6/13/2023
8.0.0-preview.4.23259.5 751 5/16/2023
8.0.0-preview.3.23174.8 2,129 4/11/2023
8.0.0-preview.2.23128.3 1,077 3/14/2023
8.0.0-preview.1.23110.8 16,830 2/21/2023
7.0.0 4,841,140 11/7/2022
7.0.0-rc.2.22472.3 10,047 10/11/2022
7.0.0-rc.1.22426.10 2,375 9/14/2022
7.0.0-preview.7.22375.6 3,085 8/9/2022
7.0.0-preview.6.22324.4 767 7/12/2022
7.0.0-preview.5.22301.12 859 6/14/2022
7.0.0-preview.4.22229.4 1,876 5/10/2022
7.0.0-preview.3.22175.4 1,107 4/13/2022
7.0.0-preview.2.22152.2 773 3/14/2022
7.0.0-preview.1.22076.8 3,355 2/17/2022
6.0.1 4,512 11/12/2024
6.0.0 10,062,501 11/8/2021
6.0.0-rc.2.21480.5 950 10/12/2021
6.0.0-rc.1.21451.13 2,156 9/14/2021
6.0.0-preview.7.21377.19 2,935 8/10/2021
6.0.0-preview.6.21352.12 1,762 7/14/2021
6.0.0-preview.5.21301.5 753 6/15/2021
6.0.0-preview.4.21253.7 11,236 5/24/2021
6.0.0-preview.3.21201.4 1,291 4/8/2021
6.0.0-preview.2.21154.6 983 3/11/2021
6.0.0-preview.1.21102.12 1,961 2/12/2021
1.0.2 450,083,671 4/8/2021
1.0.1 88,896,645 11/16/2020
1.0.0 2,304,218 11/4/2020
1.0.0-beta.2 530 11/4/2020
1.0.0-beta.1 579 11/3/2020