TimeZone Class
Important
Some information relates to prerelease product that may be substantially modified before it’s released. Microsoft makes no warranties, express or implied, with respect to the information provided here.
Caution
System.TimeZone has been deprecated. Please investigate the use of System.TimeZoneInfo instead.
Caution
System.TimeZone has been deprecated. Investigate the use of System.TimeZoneInfo instead.
Represents a time zone.
public ref class TimeZone abstract
[System.Obsolete("System.TimeZone has been deprecated. Please investigate the use of System.TimeZoneInfo instead.")]
public abstract class TimeZone
[System.Obsolete("System.TimeZone has been deprecated. Investigate the use of System.TimeZoneInfo instead.")]
public abstract class TimeZone
[System.Serializable]
public abstract class TimeZone
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public abstract class TimeZone
[<System.Obsolete("System.TimeZone has been deprecated. Please investigate the use of System.TimeZoneInfo instead.")>]
type TimeZone = class
[<System.Obsolete("System.TimeZone has been deprecated. Investigate the use of System.TimeZoneInfo instead.")>]
type TimeZone = class
[<System.Serializable>]
type TimeZone = class
[<System.Serializable>]
[<System.Runtime.InteropServices.ComVisible(true)>]
type TimeZone = class
Public MustInherit Class TimeZone
- Inheritance
-
TimeZone
- Attributes
The following example references and displays selected TimeZone
class elements.
// Example of selected TimeZone class elements.
using namespace System;
using namespace System::Globalization;
int main()
{
String^ dataFmt = "{0,-30}{1}";
String^ timeFmt = "{0,-30}{1:yyyy-MM-dd HH:mm}";
Console::WriteLine( "This example of selected TimeZone class "
"elements generates the following \n"
"output, which varies depending on the "
"time zone in which it is run.\n" );
// Get the local time zone and the current local time and year.
TimeZone^ localZone = TimeZone::CurrentTimeZone;
DateTime currentDate = DateTime::Now;
int currentYear = currentDate.Year;
// Display the names for standard time and daylight saving
// time for the local time zone.
Console::WriteLine( dataFmt, "Standard time name:", localZone->StandardName );
Console::WriteLine( dataFmt, "Daylight saving time name:", localZone->DaylightName );
// Display the current date and time and show if they occur
// in daylight saving time.
Console::WriteLine( String::Concat( "\n", timeFmt ), "Current date and time:", currentDate );
Console::WriteLine( dataFmt, "Daylight saving time?", localZone->IsDaylightSavingTime( currentDate ) );
// Get the current Coordinated Universal Time (UTC) and UTC
// offset.
DateTime currentUTC = localZone->ToUniversalTime( currentDate );
TimeSpan currentOffset = localZone->GetUtcOffset( currentDate );
Console::WriteLine( timeFmt, "Coordinated Universal Time:", currentUTC );
Console::WriteLine( dataFmt, "UTC offset:", currentOffset );
// Get the DaylightTime object for the current year.
DaylightTime^ daylight = localZone->GetDaylightChanges( currentYear );
// Display the daylight saving time range for the current year.
Console::WriteLine( "\nDaylight saving time for year {0}:", currentYear );
Console::WriteLine( "{0:yyyy-MM-dd HH:mm} to "
"{1:yyyy-MM-dd HH:mm}, delta: {2}", daylight->Start, daylight->End, daylight->Delta );
}
/*
This example of selected TimeZone class elements generates the following
output, which varies depending on the time zone in which it is run.
Standard time name: Pacific Standard Time
Daylight saving time name: Pacific Daylight Time
Current date and time: 2006-01-06 16:47
Daylight saving time? False
Coordinated Universal Time: 2006-01-07 00:47
UTC offset: -08:00:00
Daylight saving time for year 2006:
2006-04-02 02:00 to 2006-10-29 02:00, delta: 01:00:00
*/
// Example of selected TimeZone class elements.
using System;
using System.Globalization;
class TimeZoneDemo
{
static void Main( )
{
const string dataFmt = "{0,-30}{1}";
const string timeFmt = "{0,-30}{1:yyyy-MM-dd HH:mm}";
Console.WriteLine(
"This example of selected TimeZone class " +
"elements generates the following \n" +
"output, which varies depending on the " +
"time zone in which it is run.\n" );
// Get the local time zone and the current local time and year.
TimeZone localZone = TimeZone.CurrentTimeZone;
DateTime currentDate = DateTime.Now;
int currentYear = currentDate.Year;
// Display the names for standard time and daylight saving
// time for the local time zone.
Console.WriteLine( dataFmt, "Standard time name:",
localZone.StandardName );
Console.WriteLine( dataFmt, "Daylight saving time name:",
localZone.DaylightName );
// Display the current date and time and show if they occur
// in daylight saving time.
Console.WriteLine( "\n" + timeFmt, "Current date and time:",
currentDate );
Console.WriteLine( dataFmt, "Daylight saving time?",
localZone.IsDaylightSavingTime( currentDate ) );
// Get the current Coordinated Universal Time (UTC) and UTC
// offset.
DateTime currentUTC =
localZone.ToUniversalTime( currentDate );
TimeSpan currentOffset =
localZone.GetUtcOffset( currentDate );
Console.WriteLine( timeFmt, "Coordinated Universal Time:",
currentUTC );
Console.WriteLine( dataFmt, "UTC offset:", currentOffset );
// Get the DaylightTime object for the current year.
DaylightTime daylight =
localZone.GetDaylightChanges( currentYear );
// Display the daylight saving time range for the current year.
Console.WriteLine(
"\nDaylight saving time for year {0}:", currentYear );
Console.WriteLine( "{0:yyyy-MM-dd HH:mm} to " +
"{1:yyyy-MM-dd HH:mm}, delta: {2}",
daylight.Start, daylight.End, daylight.Delta );
}
}
/*
This example of selected TimeZone class elements generates the following
output, which varies depending on the time zone in which it is run.
Standard time name: Pacific Standard Time
Daylight saving time name: Pacific Daylight Time
Current date and time: 2006-01-06 16:47
Daylight saving time? False
Coordinated Universal Time: 2006-01-07 00:47
UTC offset: -08:00:00
Daylight saving time for year 2006:
2006-04-02 02:00 to 2006-10-29 02:00, delta: 01:00:00
*/
' Example of selected TimeZone class elements.
Imports System.Globalization
Module TimeZoneDemo
Sub Main( )
Const dataFmt As String = "{0,-30}{1}"
Const timeFmt As String = "{0,-30}{1:yyyy-MM-dd HH:mm}"
Console.WriteLine( "This example of selected " & _
"TimeZone class elements generates the following " & _
vbCrLf & "output, which varies depending on the " & _
"time zone in which it is run." & vbCrLf )
' Get the local time zone and the current local time and year.
Dim localZone As TimeZone = TimeZone.CurrentTimeZone
Dim currentDate As DateTime = DateTime.Now
Dim currentYear As Integer = currentDate.Year
' Display the names for standard time and daylight saving
' time for the local time zone.
Console.WriteLine( dataFmt, "Standard time name:", _
localZone.StandardName )
Console.WriteLine( dataFmt, "Daylight saving time name:", _
localZone.DaylightName )
' Display the current date and time and show if they occur
' in daylight saving time.
Console.WriteLine( vbCrLf & timeFmt, _
"Current date and time:", currentDate )
Console.WriteLine( dataFmt, "Daylight saving time?", _
localZone.IsDaylightSavingTime( currentDate ) )
' Get the current Coordinated Universal Time (UTC) and UTC
' offset.
Dim currentUTC As DateTime = _
localZone.ToUniversalTime( currentDate )
Dim currentOffset As TimeSpan = _
localZone.GetUtcOffset( currentDate )
Console.WriteLine( timeFmt, "Coordinated Universal Time:", _
currentUTC )
Console.WriteLine( dataFmt, "UTC offset:", currentOffset )
' Get the DaylightTime object for the current year.
Dim daylight As DaylightTime = _
localZone.GetDaylightChanges( currentYear )
' Display the daylight saving time range for the current year.
Console.WriteLine( vbCrLf & _
"Daylight saving time for year {0}:", currentYear )
Console.WriteLine( "{0:yyyy-MM-dd HH:mm} to " & _
"{1:yyyy-MM-dd HH:mm}, delta: {2}", _
daylight.Start, daylight.End, daylight.Delta )
End Sub
End Module
'This example of selected TimeZone class elements generates the following
'output, which varies depending on the time zone in which it is run.
'
'Standard time name: Pacific Standard Time
'Daylight saving time name: Pacific Daylight Time
'
'Current date and time: 2006-01-06 16:47
'Daylight saving time? False
'Coordinated Universal Time: 2006-01-07 00:47
'UTC offset: -08:00:00
'
'Daylight saving time for year 2006:
'2006-04-02 02:00 to 2006-10-29 02:00, delta: 01:00:00
A time zone is a geographical region in which the same standard time is used.
重要
Whenever possible, use the TimeZoneInfo class instead of the TimeZone class.
You can use the TimeZone class to retrieve information about the current time zone, and to convert times from local time to Coordinated Universal Time (UTC) or vice versa. However, you cannot use the TimeZone class to represent time zones other than the local zone or to handle date and time conversions from one time zone to another. For this purpose, use the TimeZoneInfo class. You can use this class to retrieve information on any time zone defined on the local system, to create custom time zones, and to convert times from one time zone to another.
The TimeZone class supports only a single daylight saving time adjustment rule for the local time zone. As a result, the TimeZone class can accurately report daylight saving time information or convert between UTC and local time only for the period in which the latest adjustment rule is in effect. In contrast, the TimeZoneInfo class supports multiple adjustment rules, which makes it possible to work with historic time zone data.
In addition to providing implementations for its abstract
members (those marked MustOverride
in Visual Basic), it is important that classes derived from TimeZone override the default behavior of the ToLocalTime(DateTime) method. This is because the default behavior of ToLocalTime(DateTime) in the .NET Framework version 2.0 does not depend on a call to GetUtcOffset(DateTime), as it did in the .NET Framework versions 1.0 and 1.1. For details, see the ToLocalTime(DateTime) method.
Time |
Initializes a new instance of the TimeZone class. |
Current |
Gets the time zone of the current computer. |
Daylight |
Gets the daylight saving time zone name. |
Standard |
Gets the standard time zone name. |
Equals(Object) |
Determines whether the specified object is equal to the current object. (Inherited from Object) |
Get |
Returns the daylight saving time period for a particular year. |
Get |
Serves as the default hash function. (Inherited from Object) |
Get |
Gets the Type of the current instance. (Inherited from Object) |
Get |
Returns the Coordinated Universal Time (UTC) offset for the specified local time. |
Is |
Returns a value indicating whether the specified date and time is within the specified daylight saving time period. |
Is |
Returns a value indicating whether the specified date and time is within a daylight saving time period. |
Memberwise |
Creates a shallow copy of the current Object. (Inherited from Object) |
To |
Returns the local time that corresponds to a specified date and time value. |
To |
Returns a string that represents the current object. (Inherited from Object) |
To |
Returns the Coordinated Universal Time (UTC) that corresponds to a specified time. |
产品 | 版本 (已过时) |
---|---|
.NET | (Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9) |
.NET Framework | 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1 |
.NET Standard | (2.0, 2.1) |