Udostępnij za pośrednictwem


TimeZoneInfo.HasSameRules(TimeZoneInfo) Metoda

Definicja

Wskazuje, czy bieżący obiekt i inny TimeZoneInfo obiekt mają te same reguły korekty.

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

Parametry

other
TimeZoneInfo

Drugi obiekt do porównania z bieżącym TimeZoneInfo obiektem.

Zwraca

true jeżeli dwie strefy czasowe mają identyczne reguły korekty i identyczne przesunięcie podstawowe; w przeciwnym razie , false.

Wyjątki

Parametr other ma wartość null.

Przykłady

Zazwyczaj wiele stref czasowych zdefiniowanych w rejestrze w systemie Windows i bibliotece ICU w systemach Linux i macOS ma to samo przesunięcie z uniwersalnego czasu koordynowanego (UTC) i tych samych reguł korekty. Poniższy przykład przedstawia listę tych stref czasowych w konsoli programu .

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

Uwagi

TimeZoneInfo.Equals(TimeZoneInfo) Podobnie jak metoda, metoda wskazuje, HasSameRules czy dwie strefy czasowe mają to samo przesunięcie podstawowe (zgodnie z definicją BaseUtcOffset we właściwości) i te same reguły korekty. TimeZoneInfo.Equals(TimeZoneInfo) W przeciwieństwie do metody nie HasSameRules porównuje identyfikatorów strefy czasowej (zgodnie z definicją Id we właściwości ).

Dotyczy