Partilhar via


TimeZoneInfo.HasSameRules(TimeZoneInfo) Método

Definição

Indica se o objeto atual e outro objeto TimeZoneInfo têm as mesmas regras de ajuste.

public:
 bool HasSameRules(TimeZoneInfo ^ other);
public bool HasSameRules (TimeZoneInfo other);
member this.HasSameRules : TimeZoneInfo -> bool
Public Function HasSameRules (other As TimeZoneInfo) As Boolean

Parâmetros

other
TimeZoneInfo

Um segundo objeto a ser comparado ao objeto TimeZoneInfo atual.

Retornos

true se os dois fusos horários tiverem regras de ajuste idênticas e um deslocamento de base idêntico; caso contrário, false.

Exceções

O parâmetro other é null.

Exemplos

Normalmente, vários fusos horários definidos no registro no Windows e na Biblioteca de UTI no Linux e no macOS têm o mesmo deslocamento do UTC (Tempo Universal Coordenado) e das mesmas regras de ajuste. O exemplo a seguir exibe uma lista desses fusos horários para o console.

ReadOnlyCollection<TimeZoneInfo> timeZones = TimeZoneInfo.GetSystemTimeZones();
TimeZoneInfo[] timeZoneArray = new TimeZoneInfo[timeZones.Count];
timeZones.CopyTo(timeZoneArray, 0);
// Iterate array from top to bottom
for (int ctr = timeZoneArray.GetUpperBound(0); ctr >= 1; ctr--)
{
   // Get next item from top
   TimeZoneInfo thisTimeZone = timeZoneArray[ctr];
   for (int compareCtr = 0; compareCtr <= ctr - 1; compareCtr++)
   {
      // Determine if time zones have the same rules
      if (thisTimeZone.HasSameRules(timeZoneArray[compareCtr]))
      {
         Console.WriteLine("{0} has the same rules as {1}", 
                           thisTimeZone.StandardName,
                           timeZoneArray[compareCtr].StandardName);
      }
   }
}
let timeZones = TimeZoneInfo.GetSystemTimeZones()
let timeZoneArray = Array.ofSeq timeZones
// Iterate array from top to bottom
for ctr = timeZoneArray.GetUpperBound 0 - 1 downto 0 do
    // Get next item from top
    let thisTimeZone = timeZoneArray[ctr]
    for compareCtr = 0 to ctr - 1 do
        // Determine if time zones have the same rules
        if thisTimeZone.HasSameRules timeZoneArray[compareCtr] then
            printfn $"{thisTimeZone.StandardName} has the same rules as {timeZoneArray[compareCtr].StandardName}"
Dim timeZones As ReadOnlyCollection(Of TimeZoneInfo) = TimeZoneInfo.GetSystemTimeZones()
Dim timeZoneArray(timeZones.Count - 1) As TimeZoneInfo
timeZones.CopyTo(timeZoneArray, 0) 
'Dim arrayPtr As Integer = 1
' Iterate array from top to bottom
For ctr As Integer = timeZoneArray.GetUpperBound(0) To 1 Step -1
   ' Get next item from top
   Dim thisTimeZone As TimeZoneInfo = timeZoneArray(ctr)
   For compareCtr As Integer = 0 To ctr - 1
      ' Determine if time zones have the same rules
      If thisTimeZone.HasSameRules(timeZoneArray(compareCtr)) Then
         Console.WriteLine("{0} has the same rules as {1}", _
                           thisTimeZone.StandardName, _
                           timeZoneArray(compareCtr).StandardName)
      End If                     
   Next      
Next

Comentários

Assim como o TimeZoneInfo.Equals(TimeZoneInfo) método , o HasSameRules método indica se dois fusos horários têm o mesmo deslocamento base (conforme definido pela BaseUtcOffset propriedade) e as mesmas regras de ajuste. Ao contrário do TimeZoneInfo.Equals(TimeZoneInfo) método , HasSameRules não compara identificadores de fuso horário (conforme definido pela Id propriedade ).

Aplica-se a