Microsoft MVP성태의 닷넷 이야기
닷넷: 2143. C# - 시스템 Time Zone 변경 시 이벤트 알림을 받는 방법 [링크 복사], [링크+제목 복사],
조회: 12092
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)
(시리즈 글이 8개 있습니다.)
.NET Framework: 614. C# - DateTime.Ticks의 정밀도
; https://www.sysnet.pe.kr/2/0/11082

.NET Framework: 827. C# - 인터넷 시간 서버로부터 받은 시간을 윈도우에 적용하는 방법
; https://www.sysnet.pe.kr/2/0/11883

스크립트: 33. JavaScript와 C#의 시간 변환
; https://www.sysnet.pe.kr/2/0/12849

Windows: 204.  Windows 10부터 바뀐 QueryPerformanceFrequency, QueryPerformanceCounter
; https://www.sysnet.pe.kr/2/0/13035

.NET Framework: 1997. C# - nano 시간을 가져오는 방법
; https://www.sysnet.pe.kr/2/0/13036

스크립트: 47. 파이썬의 time.time() 실숫값을 GoLang / C#에서 사용하는 방법
; https://www.sysnet.pe.kr/2/0/13308

닷넷: 2143. C# - 시스템 Time Zone 변경 시 이벤트 알림을 받는 방법
; https://www.sysnet.pe.kr/2/0/13413

닷넷: 2309. C# - .NET Core에서 바뀐 DateTime.Ticks의 정밀도
; https://www.sysnet.pe.kr/2/0/13803




C# - 시스템 Time Zone 변경 시 이벤트 알림을 받는 방법

아래와 같은 트윗이 떴군요. ^^


닷넷은 어떨까요? ^^

우선, 현재 시스템의 Time Zone은 TimeZoneInfo.Local을 이용해 구할 수 있습니다.

namespace ConsoleApp1;

internal class Program
{
    static void Main(string[] args)
    {
        while (true)
        {
            Console.WriteLine(TimeZoneInfo.Local); // TimeZone.CurrentTimeZone은 deprecated
            Thread.Sleep(1000);                
        }            
    }
}
/* 출력 결과
(UTC+09:00) Seoul
...[생략]...
*/

위와 같이 실행한 상태에서 Settings / "Time & language" 설정에 들어가 "Date & time"에서 "Time zone"을 바꾸면,

current_time_zone_1.png

콘솔 화면에는 여전히 "(UTC+09:00) Seoul"로 찍히는 것을 볼 수 있습니다.




아쉽게도, C# 역시 시스템의 Time zone에 대해 실시간 반영하는 방법은 없고, 대신에 공식 문서에도 나오듯이,

You should always access the local time zone through the TimeZoneInfo.Local property rather than assigning the local time zone to a TimeZoneInfo object variable. This prevents the TimeZoneInfo object variable from being invalidated by a call to the ClearCachedData method.


필요한 경우 ClearCachedData를 호출해야 합니다. 따라서 다음과 같이 코드를 바꾸면,

namespace ConsoleApp1;

internal class Program
{
    static void Main(string[] args)
    {
        while (true)
        {
            Console.WriteLine($"{TimeZoneInfo.Local}");
            TimeZoneInfo.ClearCachedData();

            Thread.Sleep(1000);                
        }            
    }
}

/* 출력 결과:
(UTC+09:00) Seoul
...[생략]...
(UTC+09:30) Adelaide
...[생략]...
*/

중간에 시스템의 Time Zone 변화를 반영하는 것을 볼 수 있습니다. 사실, 파이썬의 경우에도 Time Zone의 변경에 대한 알림을 받는 것은 아닐 것이므로 어차피 위의 코드와 비교해 그다지 차이가 없다고 봐야 할 것입니다.

참고로, Settings에서 변경한 Time Zone 정보는 레지스트리에 곧바로 반영됩니다.

Computer\HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\TimeZoneInformation

// 서울인 경우
current_time_zone_2.png

// Adelaide인 경우
current_time_zone_3.png

따라서, 정말로 "알림"을 받는 식으로 처리해야 한다면 윈도우의 경우 레지스트리 알림 기능을 이용해,

C# - 특정 레지스트리 변경 시 알림을 받는 방법
; https://www.sysnet.pe.kr/2/0/12621

이런 식으로 처리할 수는 있습니다.

using Microsoft.Win32;
using System.Management;

namespace ConsoleApp1;

// Nuget 패키지 참조
// Install-Package System.Management
internal class Program
{
    static void Main(string[] args)
    {
        Console.WriteLine($"{TimeZoneInfo.Local}");

        using (RegistryMonitor regMon = new RegistryMonitor(Registry.LocalMachine,
           @"SYSTEM\\CurrentControlSet\\Control\\TimeZoneInformation"))
        {
            regMon.Changed += registry_Changed;

            do
            {
                Console.WriteLine("Press 'q' key to exit...");
            } while (Console.ReadLine() != "q");
        }
    }

    private static void registry_Changed(object sender, EventArrivedEventArgs e)
    {
        TimeZoneInfo.ClearCachedData();
        Console.WriteLine($"{TimeZoneInfo.Local}");
    }
}

public class RegistryMonitor : IDisposable
{
    // 참고: https://www.sysnet.pe.kr/2/0/12621
}

(아쉽게도 Time Zone 변경에 대해 SystemParametersInfo Win32 API를 사용하지 않는 듯합니다. 그런 탓에 WM_SETTINGCHANGE 알림은 발생하지 않습니다.)




마지막으로, 윈도우의 Shell Prompt 명령어로는 tzutil을 사용할 수 있습니다.

Windows - Time zone 설정을 바꿔도 반영이 안 되는 경우
; https://www.sysnet.pe.kr/2/0/12337





[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 10/26/2023]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 91  92  93  94  95  96  97  [98]  99  100  101  102  103  104  105  ...
NoWriterDateCnt.TitleFile(s)
11484정성태4/11/201824643.NET Framework: 737. C# - async를 Task 타입이 아닌 사용자 정의 타입에 적용하는 방법파일 다운로드1
11483정성태4/10/201827936개발 환경 구성: 358. "Let's Encrypt"에서 제공하는 무료 SSL 인증서를 IIS에 적용하는 방법 (2) [1]
11482정성태4/10/201820426VC++: 126. CUDA Core 수를 알아내는 방법
11481정성태4/10/201832034개발 환경 구성: 357. CUDA의 인덱싱 관련 용어 - blockIdx, threadIdx, blockDim, gridDim
11480정성태4/9/201822071.NET Framework: 736. C# - API를 사용해 Azure에 접근하는 방법 [2]파일 다운로드1
11479정성태4/9/201817730.NET Framework: 735. Azure - PowerShell로 Access control(IAM)에 새로운 계정 만드는 방법
11478정성태11/8/201919949디버깅 기술: 115. windbg - 덤프 파일로부터 PID와 환경변수 등의 정보를 구하는 방법 [1]
11477정성태4/8/201817424오류 유형: 460. windbg - sos 명령어 수행 시 c0000006 오류 발생
11476정성태4/8/201818979디버깅 기술: 114. windbg - !threads 출력 결과로부터 닷넷 관리 스레드(System.Threading.Thread) 객체를 구하는 방법
11475정성태3/28/201821259디버깅 기술: 113. windbg - Thread.Suspend 호출 시 응용 프로그램 hang 현상에 대한 덤프 분석
11474정성태3/27/201819374오류 유형: 459. xperf: error: TEST.Event: Invalid flags. (0x3ec).
11473정성태3/22/201824570.NET Framework: 734. C# - Thread.Suspend 호출 시 응용 프로그램 hang 현상파일 다운로드2
11472정성태3/22/201818530개발 환경 구성: 356. GTX 1070, GTX 960, GT 640M의 cudaGetDeviceProperties 출력 결과
11471정성태3/20/201821915VC++: 125. CUDA로 작성한 RGB2RGBA 성능 [1]파일 다운로드1
11470정성태3/20/201823988오류 유형: 458. Visual Studio - CUDA 프로젝트 빌드 시 오류 C1189, expression must have a constant value
11469정성태3/19/201816977오류 유형: 457. error MSB3103: Invalid Resx file. Could not load file or assembly 'System.Windows.Forms, ...' or one of its dependencies.
11468정성태3/19/201816518오류 유형: 456. 닷넷 응용 프로그램 실행 시 0x80131401 예외 발생
11467정성태3/19/201816021오류 유형: 455. Visual Studio Installer - 업데이트 실패
11466정성태3/18/201817148개발 환경 구성: 355. 한 대의 PC에서 2개 이상의 DirectX 게임을 실행하는 방법
11463정성태3/15/201819527.NET Framework: 733. 스레드 간의 read/write 시에도 lock이 필요 없는 경우파일 다운로드1
11462정성태3/14/201822369개발 환경 구성: 354. HTTPS 호출에 대한 TLS 설정 확인하는 방법 [1]
11461정성태3/13/201824995오류 유형: 454. 윈도우 업데이트 설치 오류 - 0x800705b4 [1]
11460정성태3/13/201817467디버깅 기술: 112. windbg - 닷넷 메모리 덤프에서 전역 객체의 내용을 조사하는 방법
11459정성태3/13/201818266오류 유형: 453. Debug Diagnostic Tool에서 mscordacwks.dll을 찾지 못하는 문제
11458정성태2/21/201819277오류 유형: 452. This share requires the obsolete SMB1 protocol, which is unsafe and could expose your system to attack. [1]
11457정성태2/17/201823975.NET Framework: 732. C# - Task.ContinueWith 설명 [1]파일 다운로드1
... 91  92  93  94  95  96  97  [98]  99  100  101  102  103  104  105  ...