C#编程练习(03):北斗时间系统、GPS时间系统及其与UTC时间系统之间的转换

简介: C#编程练习(03):北斗时间系统、GPS时间系统及其与UTC时间系统之间的转换

需求说明:北斗周-周内秒转化为日历时,转化为UTC时,转化为GPS周周内秒

GPS周-周内秒转化为日历时,转化为UTC时,转化为北斗周-周内秒

设计示意图:

20181126094558863.jpg

源代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
//这是一个BDS/GPS周、周内秒与日历时、UTC时的转换与逆转换程序
//自定义缩略语说明:WIS为周内秒,week inner second; NYR,年月日的拼音首字母缩写
//本程序主要实现以下几个功能:
//(1) GPS Week WIS  <-->  NYR
//(2) GPS Week WIS  <-->  UTC
//(3) BDS Week WIS  <-->  NYR
//(4) BDS Week WIS  <-->  UTC
//(5) BDS Week WIS  <--> GPS Week WIS 
namespace BDS_GPS_UTC
{
    class Program
    {
        ///功能模块一:GPS周-周内秒与日历时的转换与逆转换///
        //GPS周-周内秒到年月日系统的转换
        static private DateTime gpsWeekWIS2NYR(int gpsWeek, int gpsWIS)
        {
            int difFromBegin = gpsWeek * 604800 + gpsWIS;
            DateTime gpsBeginTime = new DateTime(1980,1,6,0,0,0);
            return gpsBeginTime.AddSeconds(difFromBegin);
        }
        //GPS日历时与周-周内秒的转换
        static private int[] gpsNYR2WeekWIS(DateTime gpsNYR)
        {
            int[] gpsWeekWIS = {0, 0};               
            DateTime gpsBeginUTC = new DateTime(1980,1,6,0,0,0);
            //计算两个UTC时的时间间隔
            TimeSpan interval = gpsNYR - gpsBeginUTC;
            int gpsWeek = (int)interval.TotalSeconds / 604800;
            int gpsWIS = (int)interval.TotalSeconds % 604800;
            gpsWeekWIS[0] = gpsWeek;
            gpsWeekWIS[1] = gpsWIS;
            return gpsWeekWIS;
        }
        ///功能模块二:GPS周-周内秒与UTC时间系统的转换与逆转换///
        //GPS周-周内秒到UTC时间系统的转换
        static private DateTime gpsWeekWIS2UTC(int gpsWeek, int gpsWIS)
        {
            DateTime gpsNYR = gpsWeekWIS2NYR(gpsWeek, gpsWIS);
            //GPS日历时比UTC时快18秒
            return gpsNYR.AddSeconds(-18.0);
        }
        //GPS UTC时间系统到周-周内秒的转换
        static private int[] gpsUTC2WeekWIS(DateTime gpsUTC)
        {
            return gpsNYR2WeekWIS(gpsUTC.AddSeconds(18));
        }
        ///功能模块三:BDS周-周内秒与日历时的转换与逆转换///
        //BDS周-周内秒到年月日时间系统的转换
        static private DateTime bdsWeekWIS2NYR(int bdsWeek, int bdsWIS)
        {
            int difFromBegin = bdsWeek * 604800 + bdsWIS;
            DateTime bdsBeginTime = new DateTime(2006, 1, 1, 0, 0, 0);
            return bdsBeginTime.AddSeconds(difFromBegin);
        }
        //年月日时间系统到BDS周-周内秒的转换
        static private int[] bdsNYR2WeekWIS(DateTime bdsNYR)
        {
            //先转换到UTC时间系统
            DateTime bdsBeginUTC = new DateTime(2006, 1, 1, 0, 0, 0);
            //计算当前UTC回推出BDS起始时刻UTC的时间差
            TimeSpan interval = bdsNYR - bdsBeginUTC;
            int[] bdsWeekWIS = {0,0};
            int bdsWeek = (int)interval.TotalSeconds / 604800;
            int bdsWIS = (int)interval.TotalSeconds % 604800;
            bdsWeekWIS[0] = bdsWeek;
            bdsWeekWIS[1] = bdsWIS;
            return bdsWeekWIS;
        }
        ///功能模块四:BDS周-周内秒与UTC时间系统的转换与逆转换///
        //BDS周-周内秒到UTC时间系统的转换
        static private DateTime bdsWeekWIS2UTC(int bdsWeek, int bdsWIS)
        {
            DateTime bdsNYR = bdsWeekWIS2NYR(bdsWeek, bdsWIS);
            //BDS日历时比UTC时快4秒
            return bdsNYR.AddSeconds(-4.0);
        }
        //UTC时间系统到BDS周-周内秒的转换
        static private int[] bdsUTC2WeekWIS(DateTime bdsUTC)
        {                   
            return bdsNYR2WeekWIS(bdsUTC.AddSeconds(4));
        }
        ///功能模块五:GPS周-周内秒与BDS周-周内秒转换与逆转换///
        //GPS周-周内秒向BDS周-周周内秒的转换
        static private int[] gpsWeekWIS2bdsWeekWIS(int gpsWeek, int gpsWIS)
        {
            int[] bdsWeekWIS = {0,0};
            int difFromBegin = gpsWeek * 604800 + gpsWIS - 1356 * 604800 - 14;
            int bdsWeek = difFromBegin / 604800;
            int bdsWIS = difFromBegin % 604800;
            bdsWeekWIS[0] = bdsWeek;
            bdsWeekWIS[1] = bdsWIS;
            return bdsWeekWIS;
        }
        //BDS周-周内秒到GPS周-周内秒的转换
        static private int[] bdsWeekWIS2gpsWeekWIS(int bdsWeek, int bdsWIS)
        {
            int[] gpsWeekWIS = {0,0};
            int secDifGPS2BDS = bdsWeek * 604800 + bdsWIS + 1356 * 604800 + 14;
            int gpsWeek = secDifGPS2BDS / 604800;
            int gpsWIS = secDifGPS2BDS % 604800;
            gpsWeekWIS[0] = gpsWeek;
            gpsWeekWIS[1] = gpsWIS;
            return gpsWeekWIS;
        }
        static void Main(string[] args)
        {
            int[] gpsWeekWIS = { 2023, 432000};
            Console.Write("0 GPS周-周内秒:");
            Console.WriteLine("GPS周:{0:D},周内秒:{1:D}", gpsWeekWIS[0], gpsWeekWIS[1]);
            Console.Write("1.1 GPS周-周内秒对应日历时:");
            Console.WriteLine(gpsWeekWIS2NYR(gpsWeekWIS[0], gpsWeekWIS[1]));
            Console.Write("2.1 GPS周-周内秒对应UTC时:");
            Console.WriteLine(gpsWeekWIS2UTC(gpsWeekWIS[0], gpsWeekWIS[1]));
            Console.Write("5.1 GPS周-周内秒转BDS周-周内秒:");
            int[] bdsWeekWIS = gpsWeekWIS2bdsWeekWIS(gpsWeekWIS[0], gpsWeekWIS[1]);
            Console.WriteLine("北斗周:{0:D},周内秒: {1:D}", bdsWeekWIS[0], bdsWeekWIS[1]);
            Console.Write("3.1 BDS周-周内秒对应日历时:");
            Console.WriteLine(bdsWeekWIS2NYR(bdsWeekWIS[0], bdsWeekWIS[1]));
            Console.Write("4.1 BDS周-周内秒对应UTC时:");
            Console.WriteLine(bdsWeekWIS2UTC(bdsWeekWIS[0], bdsWeekWIS[1]));
            Console.Write("5.2 BDS周-周内秒转GPS周-周内秒:");
            int[] gpsWeekWISFromBDS = bdsWeekWIS2gpsWeekWIS(bdsWeekWIS[0], bdsWeekWIS[1]);
            Console.WriteLine("GPS周:{0:D},周内秒:{1:D}", gpsWeekWISFromBDS[0], gpsWeekWISFromBDS[1]);
            //日历时转GPS周-周内秒
            Console.Write("1.2 GPS年月日对应周-周内秒:");
            DateTime gpsNYR = new DateTime(2018, 10, 19, 0, 0, 0);
            int[] gpsWeekWISFromGpsNYR = gpsNYR2WeekWIS(gpsNYR);
            Console.WriteLine("GPS周:{0:D},周内秒:{1:D}", gpsWeekWISFromGpsNYR[0], gpsWeekWISFromGpsNYR[1]);
            //UTC时间系统转GPS周-周内秒
            Console.Write("2.2 UTC对应GPS周-周内秒:");
            DateTime gpsUTC = new DateTime(2018, 10, 18, 23, 59, 42);
            int[] gpsWeekWISFromGpsUTC = gpsUTC2WeekWIS(gpsUTC);
            Console.WriteLine("GPS周:{0:D},周内秒:{1:D}", gpsWeekWISFromGpsUTC[0], gpsWeekWISFromGpsUTC[1]);
            //日历时转BDS周-周内秒
            Console.Write("3.2 BDS年月日对应周-周内秒:");
            DateTime bdsNYR = new DateTime(2018, 10, 18, 23, 59, 46);
            int[] bdsWeekWISFrombdsNYR = bdsNYR2WeekWIS(bdsNYR);
            Console.WriteLine("bds周:{0:D},周内秒:{1:D}", bdsWeekWISFrombdsNYR[0], bdsWeekWISFrombdsNYR[1]);
            Console.Write("4.2 UTC对应bds周-周内秒:");
            DateTime bdsUTC = new DateTime(2018, 10, 18, 23, 59, 42);
            int[] bdsWeekWISFrombdsUTC = bdsUTC2WeekWIS(bdsUTC);
            Console.WriteLine("bds周:{0:D},周内秒:{1:D}", bdsWeekWISFrombdsUTC[0], bdsWeekWISFrombdsUTC[1]);
        }
    }
}

算例演示:

20181126094726943.png



相关文章
|
1月前
|
C# 开发者
C# 一分钟浅谈:Code Contracts 与契约编程
【10月更文挑战第26天】本文介绍了 C# 中的 Code Contracts,这是一个强大的工具,用于通过契约编程增强代码的健壮性和可维护性。文章从基本概念入手,详细讲解了前置条件、后置条件和对象不变量的使用方法,并通过具体代码示例进行了说明。同时,文章还探讨了常见的问题和易错点,如忘记启用静态检查、过度依赖契约和性能影响,并提供了相应的解决建议。希望读者能通过本文更好地理解和应用 Code Contracts。
37 3
|
6天前
|
存储 安全 编译器
学懂C#编程:属性(Property)的概念定义及使用详解
通过深入理解和使用C#的属性,可以编写更清晰、简洁和高效的代码,为开发高质量的应用程序奠定基础。
39 12
|
1月前
|
设计模式 C# 图形学
Unity 游戏引擎 C# 编程:一分钟浅谈
本文介绍了在 Unity 游戏开发中使用 C# 的基础知识和常见问题。从 `MonoBehavior` 类的基础用法,到变量和属性的管理,再到空引用异常、资源管理和性能优化等常见问题的解决方法。文章还探讨了单例模式、事件系统和数据持久化等高级话题,旨在帮助开发者避免常见错误,提升游戏开发效率。
52 4
|
2月前
|
存储 开发框架 .NET
C#语言如何搭建分布式文件存储系统
C#语言如何搭建分布式文件存储系统
87 2
|
3月前
|
API C#
C# 一分钟浅谈:文件系统编程
在软件开发中,文件系统操作至关重要。本文将带你快速掌握C#中文件系统编程的基础知识,涵盖基本概念、常见问题及解决方法。文章详细介绍了`System.IO`命名空间下的关键类库,并通过示例代码展示了路径处理、异常处理、并发访问等技巧,还提供了异步API和流压缩等高级技巧,帮助你写出更健壮的代码。
53 2
|
2月前
|
安全 C# 数据安全/隐私保护
实现C#编程文件夹加锁保护
【10月更文挑战第16天】本文介绍了两种用 C# 实现文件夹保护的方法:一是通过设置文件系统权限,阻止普通用户访问;二是使用加密技术,对文件夹中的文件进行加密,防止未授权访问。提供了示例代码和使用方法,适用于不同安全需求的场景。
149 0
|
3月前
|
安全 程序员 编译器
C#一分钟浅谈:泛型编程基础
在现代软件开发中,泛型编程是一项关键技能,它使开发者能够编写类型安全且可重用的代码。C# 自 2.0 版本起支持泛型编程,本文将从基础概念入手,逐步深入探讨 C# 中的泛型,并通过具体实例帮助理解常见问题及其解决方法。泛型通过类型参数替代具体类型,提高了代码复用性和类型安全性,减少了运行时性能开销。文章详细介绍了如何定义泛型类和方法,并讨论了常见的易错点及解决方案,帮助读者更好地掌握这一技术。
86 11
|
3月前
|
SQL 开发框架 安全
并发集合与任务并行库:C#中的高效编程实践
在现代软件开发中,多核处理器普及使多线程编程成为提升性能的关键。然而,传统同步模型在高并发下易引发死锁等问题。为此,.NET Framework引入了任务并行库(TPL)和并发集合,简化并发编程并增强代码可维护性。并发集合允许多线程安全访问,如`ConcurrentQueue&lt;T&gt;`和`ConcurrentDictionary&lt;TKey, TValue&gt;`,有效避免数据不一致。TPL则通过`Task`类实现异步操作,提高开发效率。正确使用这些工具可显著提升程序性能,但也需注意任务取消和异常处理等常见问题。
60 1
|
2月前
|
存储 分布式计算 监控
C# 创建一个分布式文件存储系统需要怎么设计??
C# 创建一个分布式文件存储系统需要怎么设计??
44 0