我最近作的一个项目出现了下面这样的bug。(实际代码比这个复杂的多,这里只是演示这个bug的产生。)
DateTime dt1 = new DateTime( 2005 , 5 , 31 , 15 , 31 , 00 ); string strDateTime = dt1.ToString( " u " ); // ...... 一些数据传递操作 DateTime dt2 = DateTime.Parse(strDateTime); int h = dt2.Hour;
DateTime类型的变量被转换成字符串,然后这个字符串又到处传递,走了很复杂的路,在接受方接受到这个字符串后,并再转换为DateTime格式,这时候两个时间的小时数不一样了。
上面演示中,dt1的 Hour 是 15 ,dt2 的 Hour 是 23。 进而造成我所碰到的这个bug。
解决方法,
DateTime dt1 = new DateTime( 2005 , 5 , 31 , 15 , 31 , 00 ); string strDateTime = dt1.ToString( " u " ); DateTime dt2 = DateTime.Parse(strDateTime, null ,
System.Globalization.DateTimeStyles.AdjustToUniversal); int h = dt2.Hour;
或者
DateTime dt1 = new DateTime( 2005 , 5 , 31 , 15 , 31 , 00 ); string strDateTime = dt1.ToString(); DateTime dt2 = DateTime.Parse(strDateTime); int h = dt2.Hour;
我猜想原因应该是:
我本机日期设置是某种格式,我转换为字符串的时候,用了不是我本机的这种格式(使用了UniversalSortableDateTimePattern 这种格式( using the format for universal time display )),而转换回去的时候,确用了本机默认格式,就造成了这个问题。解决方法就是通用一个识别格式。