TimeZoneInfo.HasSameRules(TimeZoneInfo) Metoda
Definicja
Ważne
Niektóre informacje odnoszą się do produktu w wersji wstępnej, który może zostać znacząco zmodyfikowany przed wydaniem. Firma Microsoft nie udziela żadnych gwarancji, jawnych lub domniemanych, w odniesieniu do informacji podanych w tym miejscu.
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 ).