TimeZoneInfo.IsAmbiguousTime Metoda
Definice
Důležité
Některé informace platí pro předběžně vydaný produkt, který se může zásadně změnit, než ho výrobce nebo autor vydá. Microsoft neposkytuje žádné záruky, výslovné ani předpokládané, týkající se zde uváděných informací.
Určuje, zda je určité datum a čas v určitém časovém pásmu nejednoznačné a lze je namapovat na dva nebo více časů UTC (Coordinated Universal Time).
Přetížení
IsAmbiguousTime(DateTime) |
Určuje, zda je určité datum a čas v určitém časovém pásmu nejednoznačné a lze je namapovat na dva nebo více časů UTC (Coordinated Universal Time). |
IsAmbiguousTime(DateTimeOffset) |
Určuje, zda je určité datum a čas v určitém časovém pásmu nejednoznačné a lze je namapovat na dva nebo více časů UTC (Coordinated Universal Time). |
IsAmbiguousTime(DateTime)
- Zdroj:
- TimeZoneInfo.cs
- Zdroj:
- TimeZoneInfo.cs
- Zdroj:
- TimeZoneInfo.cs
Určuje, zda je určité datum a čas v určitém časovém pásmu nejednoznačné a lze je namapovat na dva nebo více časů UTC (Coordinated Universal Time).
public:
bool IsAmbiguousTime(DateTime dateTime);
public bool IsAmbiguousTime (DateTime dateTime);
member this.IsAmbiguousTime : DateTime -> bool
Public Function IsAmbiguousTime (dateTime As DateTime) As Boolean
Parametry
- dateTime
- DateTime
Hodnota data a času
Návraty
true
dateTime
pokud je parametr nejednoznačný, v opačném případě false
.
Výjimky
Příklady
V tichomořském časovém pásmu končí letní čas 4. listopadu 2007 ve 2:00. Následující příklad předává čas v minutových intervalech od 12:59 4. listopadu 2007 do 2:01 do 4. listopadu 2007 na IsAmbiguousTime(DateTime) metodu TimeZoneInfo objektu, který představuje tichomořské časové pásmo. Výstup konzoly udává, že všechny časy od 4. listopadu 2007 od 1:00 do 1:59 do 4. listopadu 2007 jsou nejednoznačné.
// Specify DateTimeKind in Date constructor
DateTime baseTime = new DateTime(2007, 11, 4, 0, 59, 00, DateTimeKind.Unspecified);
DateTime newTime;
// Get Pacific Standard Time zone
TimeZoneInfo pstZone = TimeZoneInfo.FindSystemTimeZoneById("Pacific Standard Time");
// List possible ambiguous times for 63-minute interval, from 12:59 AM to 2:01 AM
for (int ctr = 0; ctr < 63; ctr++)
{
// Because of assignment, newTime.Kind is also DateTimeKind.Unspecified
newTime = baseTime.AddMinutes(ctr);
Console.WriteLine("{0} is ambiguous: {1}", newTime, pstZone.IsAmbiguousTime(newTime));
}
// Specify DateTimeKind in Date constructor
let baseTime = DateTime(2007, 11, 4, 0, 59, 00, DateTimeKind.Unspecified)
// Get Pacific Standard Time zone
let pstZone = TimeZoneInfo.FindSystemTimeZoneById "Pacific Standard Time"
// List possible ambiguous times for 63-minute interval, from 12:59 AM to 2:01 AM
for i = 0 to 62 do
// Because of assignment, newTime.Kind is also DateTimeKind.Unspecified
let newTime = baseTime.AddMinutes i
printfn $"{newTime} is ambiguous: {pstZone.IsAmbiguousTime newTime}"
' Specify DateTimeKind in Date constructor
Dim baseTime As New Date(2007, 11, 4, 0, 59, 00, DateTimeKind.Unspecified)
Dim newTime As Date
' Get Pacific Standard Time zone
Dim pstZone As TimeZoneInfo = TimeZoneInfo.FindSystemTimeZoneById("Pacific Standard Time")
' List possible ambiguous times for 63-minute interval, from 12:59 AM to 2:01 AM
For ctr As Integer = 0 To 62
' Because of assignment, newTime.Kind is also DateTimeKind.Unspecified
newTime = baseTime.AddMinutes(ctr)
Console.WriteLine("{0} is ambiguous: {1}", newTime, pstZone.IsAmbiguousTime(newTime))
Next
Poznámky
Nejednoznačný čas spadá do rozsahu časů aktuálního časového pásma. To znamená, že to může být buď standardní čas, nebo čas, který je výsledkem použití pravidla úpravy. Nejednoznačné časy jsou obvykle výsledkem, když jsou hodiny nastavené tak, aby se z letního času vrátily na standardní čas. Obrázek najdete v části Příklad.
Koordinovaný světový čas (UTC) nemá nejednoznačné časy; ani časová pásma, která letní čas nepodporují. Proto tato časová pásma nemají žádná pravidla úprav a volání IsAmbiguousTime metody vždy vrátí false
.
U časových pásem, která pozorují letní čas, závisí přesné chování této metody na relaci mezi Kind vlastností a objektem TimeZoneInfo , jak ukazuje následující tabulka.
Typ objektu TimeZoneInfo | Hodnota vlastnosti Druh | Chování |
---|---|---|
TimeZoneInfo.Local | DateTimeKind.Local nebo DateTimeKind.Unspecified | Určuje, zda dateTime je parametr nejednoznačný. |
TimeZoneInfo.Local | DateTimeKind.Utc | Převede dateTime na místní čas a pak určí, zda je tento čas nejednoznačný. |
TimeZoneInfo.Utc | DateTimeKind.Utc nebo DateTimeKind.Unspecified | Vrací objekt false . |
TimeZoneInfo.Utc | DateTimeKind.Local | Pokud dateTime je nejednoznačný, předpokládá, že se jedná o standardní čas, převede ho na UTC a vrátí false . |
Jakékoli jiné časové pásmo. | DateTimeKind.Local nebo DateTimeKind.Utc |
dateTime Převede na čas v zadaném časovém pásmu a pak určí, zda je tento čas nejednoznačný. |
Jakékoli jiné časové pásmo. | DateTimeKind.Unspecified | Určuje, jestli dateTime je nejednoznačný. |
Viz také
Platí pro
IsAmbiguousTime(DateTimeOffset)
- Zdroj:
- TimeZoneInfo.cs
- Zdroj:
- TimeZoneInfo.cs
- Zdroj:
- TimeZoneInfo.cs
Určuje, zda je určité datum a čas v určitém časovém pásmu nejednoznačné a lze je namapovat na dva nebo více časů UTC (Coordinated Universal Time).
public:
bool IsAmbiguousTime(DateTimeOffset dateTimeOffset);
public bool IsAmbiguousTime (DateTimeOffset dateTimeOffset);
member this.IsAmbiguousTime : DateTimeOffset -> bool
Public Function IsAmbiguousTime (dateTimeOffset As DateTimeOffset) As Boolean
Parametry
- dateTimeOffset
- DateTimeOffset
Datum a čas
Návraty
true
dateTimeOffset
pokud je parametr v aktuálním časovém pásmu nejednoznačný, v opačném případě false
.
Poznámky
Nejednoznačný čas spadá do rozsahu časů aktuálního časového pásma. To znamená, že to může být buď standardní čas, nebo čas, který je výsledkem použití pravidla úpravy. Nejednoznačné časy jsou obvykle výsledkem, když jsou hodiny nastavené tak, aby se z letního času vrátily na standardní čas. Koordinovaný světový čas (UTC) nemá nejednoznačné časy; ani časová pásma, která letní čas nepodporují.
Přesné chování metody závisí na vztahu mezi Offset vlastností parametru dateTimeOffset
a aktuálním časovým pásmem. Pokud je hodnota Offset vlastnosti možným posunem od UTC aktuálního časového pásma, metoda určuje, zda je toto datum a čas nejednoznačné. V opačném případě se převede dateTimeOffset
na čas v aktuálním časovém pásmu a pak určí, zda je toto datum a čas nejednoznačné.