내보내기(0) 인쇄
모두 확장
정보
요청한 주제가 아래에 표시됩니다. 그러나 이 주제는 이 라이브러리에 포함되지 않습니다.

DateTime.ToUniversalTime 메서드

2013-12-13

현재 DateTime 개체의 값을 UTC(협정 세계시)로 변환합니다.

Namespace:  System
어셈블리:  mscorlib(mscorlib.dll)

public DateTime ToUniversalTime()

반환 값

형식: System.DateTime
해당 Kind 속성이 Utc이고 해당 값이 다음 중 하나인 경우 현재 DateTime 값에 해당하는 UTC, DateTime.MaxValue(변환된 값이 너무 커서 DateTime 개체로 나타낼 수 없는 경우) 또는 DateTime.MinValue(변환된 값이 너무 작아서 DateTime 개체로 나타낼 수 없는 경우) 중 하나인 개체입니다.

UTC(협정 세계시)는 현지 시간에서 UTC 오프셋을 뺀 시간과 같습니다. 또한 변환에서는 현재 DateTime 개체가 나타내는 시간에 적용되는 일광 절약 시간 규칙도 고려합니다.

중요중요:

ToUniversalTime 메서드에서는 현지 시간을 UTC로 변환할 때 현재 조정 규칙만 인식합니다. 따라서 현재 조정 규칙이 적용되기 이전 기간에 대한 변환에는 현지 시간과 UTC 간의 차이가 정확하게 반영되지 않을 수 있습니다.

ToUniversalTime 메서드에서 반환하는 값은 현재 DateTime 개체의 Kind 속성으로 결정됩니다. 다음 표에서는 가능한 결과를 보여 줍니다.

종류

결과

Utc

변환이 수행되지 않습니다.

Local

현재 DateTime 개체가 UTC로 변환됩니다.

Unspecified

현재 DateTime 개체가 현지 시간으로 간주되고 KindLocal인 것처럼 변환이 수행됩니다.

참고참고:

ToUniversalTime 메서드는 DateTime 값을 현지 시간에서 UTC로 변환합니다. 해당 UTC 오프셋을 알 수 없는 시간을 변환하려면 ToUniversalTime 메서드를 사용합니다.

날짜 및 시간 인스턴스 값이 모호한 시간인 경우 이 메서드는 이를 표준 시간으로 가정합니다. 모호한 시간은 현지 시간대에서 표준 시간이나 일광 절약 시간에 모두 매핑될 수 있는 시간입니다. 날짜 및 시간 인스턴스 값이 잘못된 시간인 경우 이 메서드는 단순히 현지 시간대의 UTC 오프셋에서 현지 시간을 빼고 UTC를 반환합니다. 잘못된 시간이란 일광 절약 시간 조정 규칙을 적용함으로 인해 존재하지 않는 시간입니다.

호출자 참고 사항

ToUniversalTime 메서드는 때때로 로컬 시간을 UTC로 변환한 후 ToLocalTime 메서드를 호출하여 복원하는 데 사용됩니다. 그러나 원래 시간이 로컬 표준 시간대에서 잘못된 시간을 나타내는 경우 두 로컬 시간 값이 같지 않게 됩니다. 추가 정보 및 예제는 ToLocalTime 메서드를 참조하세요.

다음 예제에서는 ToUniversalTime 메서드를 보여 줍니다.


outputBlock.Text += "Enter a date and time." + "\n";
string strDateTime = System.Console.ReadLine();

System.DateTime localDateTime;
try
{
   localDateTime = System.DateTime.Parse(strDateTime);
}
catch (System.FormatException)
{
   outputBlock.Text += "Invalid format." + "\n";
   return;
}

System.DateTime univDateTime = localDateTime.ToUniversalTime();

outputBlock.Text += String.Format("{0} local time is {1} universal time.",
                   localDateTime,
                   univDateTime) + "\n";

outputBlock.Text += "Enter a date and time in universal time." + "\n";
strDateTime = System.Console.ReadLine();

try
{
   univDateTime = System.DateTime.Parse(strDateTime);
}
catch (System.FormatException)
{
   outputBlock.Text += "Invalid format." + "\n";
   return;
}

localDateTime = univDateTime.ToLocalTime();

outputBlock.Text += String.Format("{0} universal time is {1} local time.",
                   univDateTime,
                   localDateTime) + "\n";


다음 예제에서는 SpecifyKind 메서드를 사용하여, Kind 속성이 ToLocalTimeToUniversalTime 변환 메서드에 영향을 주는 방식을 보여 줍니다.


// This code example demonstrates the DateTime Kind, Now, and
// UtcNow properties, and the SpecifyKind(), ToLocalTime(), 
// and ToUniversalTime() methods.

using System;

class Example
{
   public static void Demo(System.Windows.Controls.TextBlock outputBlock)
   {
      // Get the date and time for the current moment, adjusted 
      // to the local time zone.

      DateTime saveNow = DateTime.Now;

      // Get the date and time for the current moment expressed 
      // as coordinated universal time (UTC).

      DateTime saveUtcNow = DateTime.UtcNow;
      DateTime myDt;

      // Display the value and Kind property of the current moment 
      // expressed as UTC and local time.

      DisplayNow(outputBlock, "UtcNow: ..........", saveUtcNow);
      DisplayNow(outputBlock, "Now: .............", saveNow);
      outputBlock.Text += "\n";

      // Change the Kind property of the current moment to 
      // DateTimeKind.Utc and display the result.

      myDt = DateTime.SpecifyKind(saveNow, DateTimeKind.Utc);
      Display(outputBlock, "Utc: .............", myDt);

      // Change the Kind property of the current moment to 
      // DateTimeKind.Local and display the result.

      myDt = DateTime.SpecifyKind(saveNow, DateTimeKind.Local);
      Display(outputBlock, "Local: ...........", myDt);

      // Change the Kind property of the current moment to 
      // DateTimeKind.Unspecified and display the result.

      myDt = DateTime.SpecifyKind(saveNow, DateTimeKind.Unspecified);
      Display(outputBlock, "Unspecified: .....", myDt);
   }

   // Display the value and Kind property of a DateTime structure, the 
   // DateTime structure converted to local time, and the DateTime 
   // structure converted to universal time. 

   public static string datePatt = @"M/d/yyyy hh:mm:ss tt";
   public static void Display(System.Windows.Controls.TextBlock outputBlock, string title, DateTime inputDt)
   {
      DateTime dispDt = inputDt;
      string dtString;

      // Display the original DateTime.

      dtString = dispDt.ToString(datePatt);
      outputBlock.Text += String.Format("{0} {1}, Kind = {2}",
                        title, dtString, dispDt.Kind) + "\n";

      // Convert inputDt to local time and display the result. 
      // If inputDt.Kind is DateTimeKind.Utc, the conversion is performed.
      // If inputDt.Kind is DateTimeKind.Local, the conversion is not performed.
      // If inputDt.Kind is DateTimeKind.Unspecified, the conversion is 
      // performed as if inputDt was universal time.

      dispDt = inputDt.ToLocalTime();
      dtString = dispDt.ToString(datePatt);
      outputBlock.Text += String.Format("  ToLocalTime:     {0}, Kind = {1}",
                        dtString, dispDt.Kind) + "\n";

      // Convert inputDt to universal time and display the result. 
      // If inputDt.Kind is DateTimeKind.Utc, the conversion is not performed.
      // If inputDt.Kind is DateTimeKind.Local, the conversion is performed.
      // If inputDt.Kind is DateTimeKind.Unspecified, the conversion is 
      // performed as if inputDt was local time.

      dispDt = inputDt.ToUniversalTime();
      dtString = dispDt.ToString(datePatt);
      outputBlock.Text += String.Format("  ToUniversalTime: {0}, Kind = {1}",
                        dtString, dispDt.Kind) + "\n";
      outputBlock.Text += "\n";
   }

   // Display the value and Kind property for DateTime.Now and DateTime.UtcNow.

   public static void DisplayNow(System.Windows.Controls.TextBlock outputBlock, string title, DateTime inputDt)
   {
      string dtString = inputDt.ToString(datePatt);
      outputBlock.Text += String.Format("{0} {1}, Kind = {2}",
                        title, dtString, inputDt.Kind) + "\n";
   }
}

/*
This code example produces the following results:

UtcNow: .......... 5/6/2005 09:34:42 PM, Kind = Utc
Now: ............. 5/6/2005 02:34:42 PM, Kind = Local

Utc: ............. 5/6/2005 02:34:42 PM, Kind = Utc
  ToLocalTime:     5/6/2005 07:34:42 AM, Kind = Local
  ToUniversalTime: 5/6/2005 02:34:42 PM, Kind = Utc

Local: ........... 5/6/2005 02:34:42 PM, Kind = Local
  ToLocalTime:     5/6/2005 02:34:42 PM, Kind = Local
  ToUniversalTime: 5/6/2005 09:34:42 PM, Kind = Utc

Unspecified: ..... 5/6/2005 02:34:42 PM, Kind = Unspecified
  ToLocalTime:     5/6/2005 07:34:42 AM, Kind = Local
  ToUniversalTime: 5/6/2005 09:34:42 PM, Kind = Utc

*/


Windows Phone OS

지원되는 버전: 8.0, 7.1, 7.0

Windows Phone

Microsoft는 MSDN 웹 사이트에 대한 귀하의 의견을 이해하기 위해 온라인 설문 조사를 진행하고 있습니다. 참여하도록 선택하시면 MSDN 웹 사이트에서 나가실 때 온라인 설문 조사가 표시됩니다.

참여하시겠습니까?
표시:
© 2015 Microsoft