Find the Best Cosmetic Hospitals

Explore trusted cosmetic hospitals and make a confident choice for your transformation.

“Invest in yourself — your confidence is always worth it.”

Explore Cosmetic Hospitals

Start your journey today — compare options in one place.

DOTNET: Memory Optimization in .NET with ValueTask

Here’s a single, self-contained console app that lets you experience the difference between:

  • 🚫 Without ValueTask – using async Task<int> (allocates a Task even on fast sync path)
  • With ValueTask – returning synchronously without allocating when value is cached

You’ll see timing + GC stats for both in the same run.


1️⃣ Full Code – Program.cs


This is <strong>100% self-contained</strong> – no extra packages needed.Code language: HTML, XML (xml)

2️⃣ Optional – Minimal .csproj

If you want to control the target framework explicitly, create ValueTaskDemo.csproj:

<Project Sdk="Microsoft.NET.Sdk">

  <PropertyGroup>
    <OutputType>Exe</OutputType>
    <TargetFramework>net8.0</TargetFramework>
    <ImplicitUsings>enable</ImplicitUsings>
    <Nullable>enable</Nullable>
  </PropertyGroup>

</Project>
Code language: HTML, XML (xml)

You can switch to net9.0 or net10.0 if you’re targeting .NET 9/10 SDK.


3️⃣ Step-by-Step: How to Run It

Step 1 – Create a new console project

dotnet new console -n ValueTaskDemo
cd ValueTaskDemo
Code language: JavaScript (javascript)

Step 2 – Replace Program.cs

  • Open Program.cs in your editor
  • Delete everything
  • Paste the full code from section 1️⃣

(Optionally replace the generated .csproj with the file in 2️⃣.)

Step 3 – Build and run in Release mode

dotnet run -c Release

You’ll see output similar to:

=========================================
   ValueTask Demo – Task vs ValueTask    
=========================================

Iterations : 5,000,000
Cache size : 1,000
Scenario   : All calls hit the FAST (cached) path.

Warming up (small runs)...
--- Warmup – async Task<int> ---
Iterations        : 500,000
Time Elapsed      : 80 ms
GC Gen0           : 10
GC Gen1           : 0
GC Gen2           : 0
Managed Memory Δ  : 3.20 MB
Checksum (ignore) : 499500000

--- Warmup – ValueTask<int> ---
Iterations        : 500,000
Time Elapsed      : 45 ms
GC Gen0           : 3
GC Gen1           : 0
GC Gen2           : 0
Managed Memory Δ  : 0.70 MB
Checksum (ignore) : 499500000

=========== REAL TESTS (Release) ==========

--- WITHOUT ValueTask – async Task<int> ---
Iterations        : 5,000,000
Time Elapsed      : 800 ms
GC Gen0           : 100
GC Gen1           : 5
GC Gen2           : 0
Managed Memory Δ  : 30.50 MB
Checksum (ignore) : 4995000000

--- WITH ValueTask – ValueTask<int> ---
Iterations        : 5,000,000
Time Elapsed      : 430 ms
GC Gen0           : 15
GC Gen1           : 0
GC Gen2           : 0
Managed Memory Δ  : 5.10 MB
Checksum (ignore) : 4995000000
Code language: HTML, XML (xml)

(Exact numbers will vary per machine, but the pattern should be similar.)


4️⃣ How to “Experience” and Interpret the Results

Focus on these for each scenario:

  • Time Elapsed
  • 🗑 GC Gen0 / Gen1 / Gen2
  • 💾 Managed Memory Δ

🔴 Scenario 1 – WITHOUT ValueTask (async Task)

public async Task<int> GetValueAsync(int key)
{
    if (_cache.TryGetValue(key, out var value))
    {
        return value; // looks sync, but method is async
    }

    await Task.Delay(1).ConfigureAwait(false);
    return key;
}
Code language: JavaScript (javascript)

Even when the value is immediately available in cache, the compiler:

  • Generates an async state machine
  • Allocates a Task object for each call

In a tight loop with millions of calls, you’ll see:

  • Higher Time Elapsed
  • More GC Gen0 collections
  • Higher Managed Memory Δ (more allocations)

🟢 Scenario 2 – WITH ValueTask (ValueTask)

public ValueTask<int> GetValueAsync(int key)
{
    if (_cache.TryGetValue(key, out var value))
    {
        return new ValueTask<int>(value); // completes synchronously, no Task allocation
    }

    return new ValueTask<int>(SlowPathAsync(key)); // real Task only on slow path
}
Code language: PHP (php)

Now:

  • For the fast path (cache hit), we:
    • Do not create a Task
    • Do not create a state machine
  • We only use a real Task<int> on the slow path (SlowPathAsync), which we’re not hitting in this benchmark.

In the output, you should see:

  • Lower elapsed time (less allocation + less GC work)
  • Much fewer Gen0 collections
  • Smaller Managed Memory Δ

This is exactly the use case where ValueTask shines:
A method that is often synchronous but must expose an async API.


5️⃣ Tweaks to Make the Effect More Visible

You can tune:

  • iterations (e.g., 10_000_000 if your machine is strong)
  • cacheSize (smaller cache keeps hit ratio at 100%)
const int iterations = 10_000_000;
const int cacheSize = 100;
Code language: JavaScript (javascript)

This increases the number of fast-path calls and magnifies the Task vs ValueTask difference.


Find Trusted Cardiac Hospitals

Compare heart hospitals by city and services — all in one place.

Explore Hospitals
I’m a DevOps/SRE/DevSecOps/Cloud Expert passionate about sharing knowledge and experiences. I have worked at <a href="https://www.cotocus.com/">Cotocus</a>. I share tech blog at <a href="https://www.devopsschool.com/">DevOps School</a>, travel stories at <a href="https://www.holidaylandmark.com/">Holiday Landmark</a>, stock market tips at <a href="https://www.stocksmantra.in/">Stocks Mantra</a>, health and fitness guidance at <a href="https://www.mymedicplus.com/">My Medic Plus</a>, product reviews at <a href="https://www.truereviewnow.com/">TrueReviewNow</a> , and SEO strategies at <a href="https://www.wizbrand.com/">Wizbrand.</a> Do you want to learn <a href="https://www.quantumuting.com/">Quantum Computing</a>? <strong>Please find my social handles as below;</strong> <a href="https://www.rajeshkumar.xyz/">Rajesh Kumar Personal Website</a> <a href="https://www.youtube.com/TheDevOpsSchool">Rajesh Kumar at YOUTUBE</a> <a href="https://www.instagram.com/rajeshkumarin">Rajesh Kumar at INSTAGRAM</a> <a href="https://x.com/RajeshKumarIn">Rajesh Kumar at X</a> <a href="https://www.facebook.com/RajeshKumarLog">Rajesh Kumar at FACEBOOK</a> <a href="https://www.linkedin.com/in/rajeshkumarin/">Rajesh Kumar at LINKEDIN</a> <a href="https://www.wizbrand.com/rajeshkumar">Rajesh Kumar at WIZBRAND</a> <a href="https://www.rajeshkumar.xyz/dailylogs">Rajesh Kumar DailyLogs</a>

Related Posts

The DevOps Guide to Agentless Security: Scaling Protection without Breaking the Build

Today’s DevOps teams need to innovate, accelerate development, and minimize friction. In parallel, securing cloud-native environments is more challenging. Software now runs on containers, virtual machines, serverless,…

Read More

Top 10 Field Service Management (FSM) Software: Features, Pros, Cons & Comparison

Introduction Field Service Management (FSM) software is a category of business applications designed to help organizations plan, schedule, dispatch, track, and optimize field service operations. These tools…

Read More

How to Connect a WordPress Website Using an FTP Client?

Introduction -H2 Sometimes, during installing plugins or custom themes, people face issues of WordPress website breakdown. This happens due to the WordPress dashboard not accepting the new…

Read More

The Evolution of DevOps: Bridging the Gap Between Development and Operations

The Origins of DevOps The concept of DevOps emerged as a response to the traditional separation between software development and IT operations. Historically, these two disciplines operated…

Read More

B2B Gifting for DevOps and Engineering Teams: What Actually Works

Employee and client recognition is an established part of business culture, but for DevOps and engineering teams, the standard corporate gifting playbook rarely lands well. A generic…

Read More

How DevOps Teams Automate Ticket Creation from Monitoring and Backup Systems

There are 5,000 alerts generated every day in the average enterprise DevOps environment. But most of these alerts never reach a human until a system fails completely….

Read More
Subscribe
Notify of
guest
2 Comments
Newest
Oldest Most Voted
Inline Feedbacks
View all comments
Skylar Bennett
Skylar Bennett
4 months ago

This blog clearly explains how using ValueTask can help optimize memory usage and improve performance in .NET applications, especially in high-throughput or asynchronous scenarios. It highlights when ValueTask is a better choice than Task and cautions readers about proper usage to avoid common pitfalls. The practical focus on reducing allocations and improving efficiency makes the content very relevant for developers building scalable and responsive systems. Overall, the article provides useful guidance for .NET professionals who want to make informed design decisions and write more performance-aware asynchronous code.

Jason Mitchell
Jason Mitchell
5 months ago

This article provides a very clear explanation of how ValueTask can significantly improve memory efficiency in .NET applications, especially in scenarios where asynchronous operations often complete synchronously. By reducing unnecessary heap allocations and lowering GC pressure, ValueTask becomes a powerful tool for developers working on high-performance or high-frequency code paths. I appreciate how the blog highlights not only the benefits but also the correct usage patterns, helping readers understand when ValueTask is appropriate and when a regular Task is still the better choice. Overall, this is a very practical and insightful guide for anyone looking to optimize memory usage and improve the responsiveness of their .NET applications.

2
0
Would love your thoughts, please comment.x
()
x