Partilhar via


DateTime.Ticks Propriedade

Definição

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 Localcomo , 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 Utccomo , 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 Unspecifiedcomo , 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 .

Aplica-se a