Languages
[Edit]
EN

C# / .NET - get current machine time in nanoseconds

8 points
Created by:
Marcin
2441

This posts is an answer for a common question:

How to get java System.nanoTime() in C# / .NET? 

It is possible in following way.

Getting nano time with Stopwatch.GetTimestamp method example

using System.Diagnostics;

public static class TimeUtils
{
	public static long GetNanoseconds()
	{
		double timestamp = Stopwatch.GetTimestamp();
		double nanoseconds = 1_000_000_000.0 * timestamp / Stopwatch.Frequency;

		return (long)nanoseconds;
	}
}

Example:

long t1 = TimeUtils.GetNanoseconds();

Thread.Sleep(1000);

long t2 = TimeUtils.GetNanoseconds();
long dt = t2 - t1;

Console.WriteLine(t2 + " - " + t1 + " = " + dt + " ns");

Output:

193915543540248 - 193914543003928 = 1000536320 ns
Notes: 
  • Stopwatch.GetTimestamp returns time from timer mechanism - system up time.
  • The best application of this time could be measuring how much time took some operations.

References

  1. Stopwatch.GetTimestamp Method - Microsoft Docs

Checkout latest findings & news:

Checkout latest questions:

Checkout latest wiki articles:

Hey 👋
Would you like to know what we do?
  • Dirask is a friendly IT community for learners, professionals and hobbyists to share their knowledge and help each other in extraordinary easy way.
  • We welcome everyone,
    no matter what the experience,
    no matter how basic the question is,
    this community will help you.
Rockstar community members
Thank you for great work 👍