Heim >Web-Frontend >js-Tutorial >So erhalten Sie Zeitstempel und Zeitunterschied in NodeJS

So erhalten Sie Zeitstempel und Zeitunterschied in NodeJS

高洛峰
高洛峰Original
2017-02-04 11:02:521326Durchsuche

Es gibt viele Möglichkeiten, Zeitstempel in Nodejs zu erhalten, zum Beispiel:

1.new Date().getTime()

2.Date.now()

3.process.uptime()

4.process.hrtime()

Wenn Sie normalerweise einen Zeitstempel erhalten möchten, verwenden Sie diese Methoden Alle sind in Ordnung, was ist also der Unterschied zwischen diesen Methoden?

new Date().getTime() und Date.now()

Diese Methoden basieren auf der Systemzeit in Millisekunden der Knotenlaufumgebung, dem Effekt des Schreibens von +new Date() method und new Date ().getTime() haben den gleichen Effekt.

In Szenarien, in denen häufig Zeitstempel verwendet werden, müssen Sie auf die Methodenleistung achten. Von diesen Methoden weist Date.now() die beste Leistung auf und kann mit ein wenig Code getestet werden:

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);

Ausgabeergebnis:

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

[+new Date]interval : 2189

[Date.now()]interval: 891

Wenn Sie nur den Zeitstempel erhalten, ist die Verwendung von Date.now() der beste Weg, aber wenn Sie den Zeitstempel berechnen möchten Zeitunterschied, diese Bei dieser Methode gibt es einige Probleme: Die Systemzeit der laufenden Umgebung weist manchmal einen leichten Rückruf auf, sodass der erhaltene Zeitunterschied nicht genau ist und manchmal einige Fehler verursacht werden.

process.hrtime()

Diese Methode dient dazu, ein genaues Zeitstempelobjekt basierend auf einem beliebigen vergangenen Zeitpunkt und der Zeit ab jetzt zu erhalten: [Sekunden, Nanosekunden]

> process.hrtime()
[ 3197146, 563552237 ]

Diese Methode hat nichts mit der Systemzeit zu tun, daher wird sie nicht von der Abweichung der Systemuhr beeinflusst und es tritt kein Fehler auf, wenn sie zur Berechnung des Zeitunterschieds verwendet wird. .

Es gibt jedoch immer ein Aber- -

Was ist, wenn es an einem Ort verwendet wird, der häufig angerufen wird?

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);

[hrTime]interval: 6412 6413 Wenn ich mich richtig erinnere, dauert das obige Date.now() etwa 900 ms für die gleiche Anzahl an Kreationen!

process.hrtime() ist zu langsam! ! !

Es stellt sich heraus, dass die Berechnung komplizierter ist, viele Systemressourcen beansprucht und langsam ist, wenn nodejs hochpräzise Zeit verarbeitet, sodass diese Methode nicht für Hochfrequenzanwendungen geeignet ist. Siehe unten: process.uptime()

process.uptime()

Diese Funktion nutzt die Startlaufzeit von nodejs, um einen Zeitstempel in Sekunden mit einer Genauigkeit von Millisekunden zu erhalten:

process.uptime

Eingabe: 6.419

Diese Funktion basiert auf der Startzeit des Knotens. Sie wird auch nicht von der Systemuhrabweichung beeinflusst und eignet sich zur Berechnung der Zeitdifferenz.

Wie ist die Leistung so vieler Anrufe?

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);

Ausgabe: [process.uptime()] Intervall: 954

Im Vergleich zu Process.hrtime() ist die Leistung viel besser~

Rechne nicht so genau, sei einfach schnell!

Wenn Sie dann den Zeitunterschied bei hoher Frequenz berechnen müssen, sind Sie es!

Das Obige ist der gesamte Inhalt von NodeJS, um Zeitstempel und Zeitunterschiede zu erhalten. Ich hoffe, dass er für alle hilfreich ist, wenn er NodeJS verwendet.

Weitere Artikel zum Abrufen von Zeitstempeln und Zeitunterschieden in NodeJS finden Sie auf der chinesischen PHP-Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn