TimeZoneInfo.HasSameRules(TimeZoneInfo) Método

Definición

Indica si el objeto actual y otro objeto TimeZoneInfo tienen las mismas reglas 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

Segundo objeto que se va a comparar con el objeto TimeZoneInfo actual.

Devoluciones

Es true si las dos zonas horarias tienen reglas de ajuste idénticas y un desplazamiento base idéntico; en caso contrario, es false.

Excepciones

El parámetro other es null.

Ejemplos

Normalmente, una serie de zonas horarias definidas en el registro en Windows y la biblioteca de ICU en Linux y macOS tienen el mismo desplazamiento de la hora universal coordinada (UTC) y las mismas reglas de ajuste. En el ejemplo siguiente se muestra una lista de estas zonas horarias en la consola.

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

Comentarios

Al igual que el TimeZoneInfo.Equals(TimeZoneInfo) método , el HasSameRules método indica si dos zonas horarias tienen el mismo desplazamiento base (según lo definido por la BaseUtcOffset propiedad ) y las mismas reglas de ajuste. A diferencia del TimeZoneInfo.Equals(TimeZoneInfo) método , HasSameRules no compara los identificadores de zona horaria (como se define en la Id propiedad ).

Se aplica a