我最近作的一个项目出现了下面这样的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 )),而转换回去的时候,确用了本机默认格式,就造成了这个问题。解决方法就是通用一个识别格式。