DateTime.Ticks Propriedade
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Obtém o número de tiques que representam a data e hora dessa instância.
public:
property long Ticks { long get(); };
public long Ticks { get; }
member this.Ticks : int64
Public ReadOnly Property Ticks As Long
Valor da propriedade
O número de tiques que representam a data e hora dessa instância. O valor está entre DateTime.MinValue.Ticks
e DateTime.MaxValue.Ticks
.
Exemplos
O exemplo a seguir usa a Ticks propriedade para exibir o número de tiques decorridos desde o início do século XXI e para instanciar um TimeSpan objeto . Em TimeSpan seguida, o objeto é usado para exibir o tempo decorrido usando vários outros intervalos de tempo.
DateTime centuryBegin = new DateTime(2001, 1, 1);
DateTime currentDate = DateTime.Now;
long elapsedTicks = currentDate.Ticks - centuryBegin.Ticks;
TimeSpan elapsedSpan = new TimeSpan(elapsedTicks);
Console.WriteLine("Elapsed from the beginning of the century to {0:f}:",
currentDate);
Console.WriteLine(" {0:N0} nanoseconds", elapsedTicks * 100);
Console.WriteLine(" {0:N0} ticks", elapsedTicks);
Console.WriteLine(" {0:N2} seconds", elapsedSpan.TotalSeconds);
Console.WriteLine(" {0:N2} minutes", elapsedSpan.TotalMinutes);
Console.WriteLine(" {0:N0} days, {1} hours, {2} minutes, {3} seconds",
elapsedSpan.Days, elapsedSpan.Hours,
elapsedSpan.Minutes, elapsedSpan.Seconds);
// This example displays an output similar to the following:
//
// Elapsed from the beginning of the century to Thursday, 14 November 2019 18:21:
// 595,448,498,171,000,000 nanoseconds
// 5,954,484,981,710,000 ticks
// 595,448,498.17 seconds
// 9,924,141.64 minutes
// 6,891 days, 18 hours, 21 minutes, 38 seconds
open System
let centuryBegin = DateTime(2001, 1, 1)
let currentDate = DateTime.Now
let elapsedTicks = currentDate.Ticks - centuryBegin.Ticks
let elapsedSpan = TimeSpan elapsedTicks
printfn $"Elapsed from the beginning of the century to {currentDate:f}:"
printfn $" {elapsedTicks * 100L:N0} nanoseconds"
printfn $" {elapsedTicks:N0} ticks"
printfn $" {elapsedSpan.TotalSeconds:N2} seconds"
printfn $" {elapsedSpan.TotalMinutes:N2} minutes"
printfn $" {elapsedSpan.Days:N0} days, {elapsedSpan.Hours} hours, {elapsedSpan.Minutes} minutes, {elapsedSpan.Seconds} seconds"
// This example displays an output similar to the following:
//
// Elapsed from the beginning of the century to Thursday, 14 November 2019 18:21:
// 595,448,498,171,000,000 nanoseconds
// 5,954,484,981,710,000 ticks
// 595,448,498.17 seconds
// 9,924,141.64 minutes
// 6,891 days, 18 hours, 21 minutes, 38 seconds
Dim centuryBegin As Date = #1/1/2001 0:0:0#
Dim currentDate As Date = Date.Now
Dim elapsedTicks As Long = currentDate.Ticks - centuryBegin.Ticks
Dim elapsedSpan As New TimeSpan(elapsedTicks)
Console.WriteLine("Elapsed from the beginning of the century to {0:f}:", _
currentDate)
Console.WriteLine(" {0:N0} nanoseconds", elapsedTicks * 100)
Console.WriteLine(" {0:N0} ticks", elapsedTicks)
Console.WriteLine(" {0:N2} seconds", elapsedSpan.TotalSeconds)
Console.WriteLine(" {0:N2} minutes", elapsedSpan.TotalMinutes)
Console.WriteLine(" {0:N0} days, {1} hours, {2} minutes, {3} seconds", _
elapsedSpan.Days, elapsedSpan.Hours, _
elapsedSpan.Minutes, elapsedSpan.Seconds)
' If run on December 14, 2007, at 15:23, this example displays the
' following output to the console:
' 219,338,580,000,000,000 nanoseconds
' 2,193,385,800,000,000 ticks
' 219,338,580.00 seconds
' 3,655,643.00 minutes
' 2,538 days, 15 hours, 23 minutes, 0 seconds
Comentários
Um único tique representa cem nanossegundos ou um décimo milionésimo de segundo. Há 10.000 tiques em milissegundos (veja TicksPerMillisecond) e 10 milhões de tiques em um segundo.
O valor dessa propriedade representa o número de intervalos de 100 nanossegundos decorridos desde 12:00:00 meia-noite de 1º de janeiro de 0001 no calendário gregoriano, que representa MinValue. Ele não inclui o número de tiques atribuíveis a segundos bissextos.
Se o objeto DateTime tiver sua Kind
propriedade definida Local
como , seus tiques representarão o tempo decorrido desde 12:00:00 meia-noite, 1º de janeiro de 0001 na hora local, conforme especificado pela configuração de fuso horário atual.
Se o DateTime
objeto tiver sua Kind
propriedade definida Utc
como , seus tiques representarão o tempo decorrido desde 12:00:00 meia-noite, 1º de janeiro de 0001 no Tempo Universal Coordenado.
Se o DateTime
objeto tiver sua Kind
propriedade definida Unspecified
como , seus tiques representarão o tempo decorrido desde 12:00:00 meia-noite, 1º de janeiro de 0001 no fuso horário desconhecido.
Em geral, os tiques representam a hora de acordo com o fuso horário especificado pela Kind
propriedade .