윈도우와 유닉스는 시간단위가 달라서 서로 호환이 안됩니다.

윈도우 시간은 64비트 정수에 1601년 1월 1일 부터 100나노 초 단위로 1씩 증가하고, 유닉스 시간은 32비트 정수에 1970년 1월 1일부터 1초 단위로 1씩 증가합니다.

특히나 윈도우에서 사용되는 C 표준함수(C Run-Time Library)들은 유닉스와 같이 1970년 1월 1일을 기준으로 날짜를 처리합니다.

그래서 윈도우 API와 C 표준함수를 섞어서 프로그램을 만들었을 경우 시간 단위가 맞지 않게 됩니다. 윈도우 API만 사용하거나 C 표준함수만 사용하여 프로그램을 만드는 것이 좋겠지만 섞어서 쓰게되는 경우가 있을 수 있습니다. 예를 들면 유닉스(리눅스)의 프로그램을 윈도우에 포팅한다거나 그 반대의 경우입니다. 이럴 때 두 시간 단위를 어떻게 변환하는지 설명하겠습니다.

윈도우 시간에서 유닉스 시간으로 변환

윈도우 시간은 1601년 부터 시작했고 유닉스 시간은 1970년 부터 시작했기 때문에 먼저 시작한 윈도우 시간이 훨씬 숫자가 큽니다. 윈도우 시간 단위(100나노 초)를 유닉스 시간 단위(1초)로 변환 한 뒤, 1601에서 1970년의 차이인 369년을 빼주면 됩니다.

유닉스 시간에서 윈도우 시간으로 변환

위와 반대로 유닉스 시간이 나중에 시작 했기 때문에 윈도우 시간보다 숫자가 작습니다. 유닉스 시간 단위(1초)에서 윈도우 시간 단위(100나노 초)로 변환한 뒤 1601년과 1970년의 차이인 369년을 더해주면 됩니다.

그럼 이제 실제로 계산을 해보겠습니다.

윈도우 -> 유닉스 윈도우 시간 / 10000000을 하면 유닉스 시간 단위인 1초 단위가 됩니다. 1초는 1000000000나노 초이기 때문에 윈도우에서는 1초가 10000000입니다(100나노초가 최소 단위이므로).

여기에 369년을 뺍니다. 369년 x 365일 = 134685일이고 여기에 89일을 뺀 134774일을 빼야 합니다. 왜 89일이냐하면 1601년과 1970년 사이에 윤년이 계산상으로는 92개지만, 한 세기가 시작하는 해는 윤년이 아닙니다. 즉 1700, 1800, 1900년은 윤년이 아니므로 이 3개를 제외하면 실제 윤년은 89개가 됩니다(윤년은 하루가 더 길기 때문에 때문에 89일이 됩니다).

(참고로 한 세기가 시작하는 해라고 하더라도 400으로 나누어 떨어지는 해는 윤년이 아닙니다. 즉 1600년, 2000년은 윤년이 아닙니다.)

134774일을 초로 바꾸면 134774일 x 24시간 x 60분 x 60초 = 11644473600초가 되고 유닉스 시간단위로 변환한 값에 11644473600초를 빼면 됩니다.

유닉스 -> 윈도우 유닉스 시간에 11644473600초를 먼저 더한 값을 윈도우 시간 단위로 변환합니다. 유닉스 시간 * 10000000을 하면 100나노 초 단위인 윈도우 시간이 됩니다. (윈도우 시간으로 먼저 변환한 뒤 100나노초 단위인 116444736000000000을 더해줘도 됩니다.) 물론 변수는 64비트 정수형을 사용해야 하겠죠.

간단하게 하면 정리를 하면 윈도우 -> 유닉스 : 윈도우 / 10000000 - 11644473600 유닉스 -> 윈도우 : (유닉스 + 11644473600) * 10000000 혹은 유닉스 * 10000000 + 116444736000000000


저작권 안내

이 웹사이트에 게시된 모든 글의 무단 복제 및 도용을 금지합니다.
  • 블로그, 게시판 등에 퍼가는 것을 금지합니다.
  • 비공개 포스트에 퍼가는 것을 금지합니다.
  • 글 내용, 그림을 발췌 및 요약하는 것을 금지합니다.
  • 링크 및 SNS 공유는 허용합니다.

Published

14 April 2007