Home Web Front-end JS Tutorial How to get timestamp and time difference in nodejs

How to get timestamp and time difference in nodejs

Feb 04, 2017 am 11:02 AM

There are many ways to get timestamps in Nodejs, for example:

1.new Date().getTime()

2.Date.now()

3.process.uptime()

4.process.hrtime()

If you usually want to get a timestamp, use these methods All are ok, so what’s the difference between these methods?

new Date().getTime() and Date.now()

These methods are based on the system time milliseconds of the node running environment, the effect of +new Date() writing method and new Date ().getTime() has the same effect.

In scenarios where timestamps are frequently used, you need to pay attention to method performance. Among these methods, Date.now() has the best performance and can be tested with a little code:

var t1 = new Date().getTime();
var t2 = t1;
var i = 0, count = 10000000, interval = 0;
 
for(i = 0; i < count; i++)
{
  t2 = new Date().getTime();
  interval = (t2 - t1);
}
interval = (t2 - t1);
console.log(&#39;【new Date().getTime()】interval: &#39;, interval);
 
t1 = new Date().getTime();
for(i = 0; i < count; i++)
{
  t2 = +new Date;
  interval = (t2 - t1);
}
interval = (t2 - t1);
console.log(&#39;【+new Date】interval: &#39;, interval);
 
t1 = new Date().getTime();
for(i = 0; i < count; i++)
{
  t2 = Date.now();
  interval = (t2 - t1);
}
interval = (t2 - t1);
console.log(&#39;【Date.now()】interval: &#39;, interval);
Copy after login

Output result:

[new Date().getTime()]interval: 1583

[+new Date]interval: 2189

[Date.now()]interval: 891

If you just get the timestamp, then using Date.now() is the best way, but if you want to calculate the time difference, these methods are There will be some problems: the system time of the running environment sometimes has a slight callback, so the time difference obtained is not accurate, and sometimes some BUGs will be caused.

process.hrtime()

This method is to obtain an accurate timestamp object based on an arbitrary past time point and the time from now: [seconds, nanoseconds]

> process.hrtime()
[ 3197146, 563552237 ]
Copy after login

This method has nothing to do with system time, so it will not be affected by system clock drift, and there will be no BUG when used to calculate the time difference.

But, there are always buts in everything - -

What if it is used in a place that is frequently called?

var t1 = new Date().getTime();
var t2 = t1;
var i = 0, count = 10000000, interval = 0;
 
var hrTime1 = process.hrtime();
var hrTime2 = hrTime1;
 
t1 = new Date().getTime();
for(i = 0; i < count; i++)
{
  hrTime2 = process.hrtime(hrTime1);
}
t2 = new Date().getTime();
interval = parseInt(hrTime2[0] * 1e3 + hrTime2[1] * 1e-6);
console.log(&#39;【hrTime】interval: &#39;, interval, t2 - t1);
Copy after login

[hrTime]interval: 6412 6413 If I remember correctly, the above Date.now() is about 900ms for the same number of creations!

process.hrtime() is too slow! ! !

It turns out that when nodejs handles high-precision time, the calculation is more complicated, takes up a lot of system resources, and is slow, so this method is not suitable for high-frequency applications. Please see below process.uptime()

process.uptime()

This function uses nodejs to start the running time to get a timestamp in seconds, accurate to milliseconds:

process.uptime

Input: 6.419

This function is based on the node startup time. It is also not affected by the system clock drift and is suitable for calculating time differences.

How is the performance of so many calls?

var t1 = new Date().getTime();
var t2 = t1;
var i = 0, count = 10000000, interval = 0;
 
t1 = process.uptime()*1000;
for(i = 0; i < count; i++)
{
  t2 = process.uptime()*1000;
  //interval = (t2 - t1);
}
interval = (t2 - t1);
console.log(&#39;【process.uptime()】interval: &#39;, interval);
Copy after login

Output: [process.uptime()]interval: 954

Compared with process.hrtime(), the performance is much better~

Don’t need to calculate so accurately, just be fast!

Then where you need to calculate the time difference at high frequency, it’s you!

The above is the entire content of nodejs for obtaining timestamp and time difference. I hope it will be helpful to everyone when using nodejs.

For more articles related to how nodejs obtains timestamps and time differences, please pay attention to the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat Commands and How to Use Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How do I create and publish my own JavaScript libraries? How do I create and publish my own JavaScript libraries? Mar 18, 2025 pm 03:12 PM

Article discusses creating, publishing, and maintaining JavaScript libraries, focusing on planning, development, testing, documentation, and promotion strategies.

How do I optimize JavaScript code for performance in the browser? How do I optimize JavaScript code for performance in the browser? Mar 18, 2025 pm 03:14 PM

The article discusses strategies for optimizing JavaScript performance in browsers, focusing on reducing execution time and minimizing impact on page load speed.

What should I do if I encounter garbled code printing for front-end thermal paper receipts? What should I do if I encounter garbled code printing for front-end thermal paper receipts? Apr 04, 2025 pm 02:42 PM

Frequently Asked Questions and Solutions for Front-end Thermal Paper Ticket Printing In Front-end Development, Ticket Printing is a common requirement. However, many developers are implementing...

How do I debug JavaScript code effectively using browser developer tools? How do I debug JavaScript code effectively using browser developer tools? Mar 18, 2025 pm 03:16 PM

The article discusses effective JavaScript debugging using browser developer tools, focusing on setting breakpoints, using the console, and analyzing performance.

Who gets paid more Python or JavaScript? Who gets paid more Python or JavaScript? Apr 04, 2025 am 12:09 AM

There is no absolute salary for Python and JavaScript developers, depending on skills and industry needs. 1. Python may be paid more in data science and machine learning. 2. JavaScript has great demand in front-end and full-stack development, and its salary is also considerable. 3. Influencing factors include experience, geographical location, company size and specific skills.

How do I use source maps to debug minified JavaScript code? How do I use source maps to debug minified JavaScript code? Mar 18, 2025 pm 03:17 PM

The article explains how to use source maps to debug minified JavaScript by mapping it back to the original code. It discusses enabling source maps, setting breakpoints, and using tools like Chrome DevTools and Webpack.

How to merge array elements with the same ID into one object using JavaScript? How to merge array elements with the same ID into one object using JavaScript? Apr 04, 2025 pm 05:09 PM

How to merge array elements with the same ID into one object in JavaScript? When processing data, we often encounter the need to have the same ID...

The difference in console.log output result: Why are the two calls different? The difference in console.log output result: Why are the two calls different? Apr 04, 2025 pm 05:12 PM

In-depth discussion of the root causes of the difference in console.log output. This article will analyze the differences in the output results of console.log function in a piece of code and explain the reasons behind it. �...

See all articles