C# 根据当前时间获取,本周,本月,本季度等时间段 .Net中Exception
2011-09-05 17:49
603 查看
DateTimedt
=DateTime.Now;//当前时间
DateTimestartWeek=dt.AddDays(1
-Convert.ToInt32(dt.DayOfWeek.ToString("d")));//本周周一
DateTimeendWeek
=startWeek.AddDays(6);//本周周日
DateTimestartMonth=dt.AddDays(1
-dt.Day);//本月月初
DateTimeendMonth
=startMonth.AddMonths(1).AddDays(-1);//本月月末
//DateTimeendMonth=startMonth.AddDays((dt.AddMonths(1)-dt).Days-1);//本月月末
DateTimestartQuarter=dt.AddMonths(0
-(dt.Month
-1)
%3).AddDays(1
-dt.Day);//本季度初
DateTimeendQuarter
=startQuarter.AddMonths(3).AddDays(-1);//本季度末
DateTimestartYear=
newDateTime(dt.Year,1,1);//本年年初
DateTimeendYear
=newDateTime(dt.Year,12,31);//本年年末
至于昨天、明天、上周、上月、上季度、上年度等等,只要AddDays()、AddMonths()、AddYears()这几种方法组合一下就可以了。
C#中datetime的使用
//如果你还不明白,再看一下中文显示星期几的方法就应该懂了
//由于DayOfWeek返回的是数字的星期几,我们要把它转换成汉字方便我们阅读,有些人可能会用switch来一个一个地对照,其实不用那么麻烦的
string[]Day
=new
string[]{"星期日","星期一","星期二","星期三","星期四","星期五","星期六"};
stringweek
=Day[Convert.ToInt32(DateTime.Now.DayOfWeek.ToString("d"))].ToString();//上周,同理,一个周是7天,上周就是本周再减去7天,下周也是一样
DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))-7);//上周一
DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))-7).AddDays(6);//上周末(星期日)
//下周
DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))+7);//下周一
DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))+7).AddDays(6);//下周末
//本月,很多人都会说本月的第一天嘛肯定是1号,最后一天就是下个月一号再减一天。当然这是对的
//一般的写法
DateTime.Now.Year.ToString()
+DateTime.Now.Month.ToString()
+"1";//第一天
DateTime.Parse(DateTime.Now.Year.ToString()
+DateTime.Now.Month.ToString()
+"1").AddMonths(1).AddDays(-1).ToShortDateString();//最后一天
//巧用C#里ToString的字符格式化更简便
DateTime.Now.ToString("yyyy-MM-01");DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(1).AddDays(-1).ToShortDateString();//上个月,减去一个月份
DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(-1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();//下个月,加去一个月份
DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(2).AddDays(-1).ToShortDateString();//7天后
DateTime.Now.Date.ToShortDateString();DateTime.Now.AddDays(7).ToShortDateString();//7天前
DateTime.Now.AddDays(-7).ToShortDateString();DateTime.Now.Date.ToShortDateString();//本年度,用ToString的字符格式化我们也很容易地算出本年度的第一天和最后一天
DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(1).AddDays(-1).ToShortDateString();//上年度,不用再解释了吧
DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(-1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddDays(-1).ToShortDateString();//下年度
DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(2).AddDays(-1).ToShortDateString();//本季度,很多人都会觉得这里难点,需要写个长长的过程来判断。其实不用的,我们都知道一年四个季度,一个季度三个月
//首先我们先把日期推到本季度第一个月,然后这个月的第一天就是本季度的第一天了
DateTime.Now.AddMonths(0
-((DateTime.Now.Month
-1)
%3)).AddDays(1
-DateTime.Now.Day);//同理,本季度的最后一天就是下季度的第一天减一
DateTime.Parse(DateTime.Now.AddMonths(3
-((DateTime.Now.Month
-1)
%3)).ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();//下季度,相信你们都知道了。。。。收工
DateTime.Now.AddMonths(3
-((DateTime.Now.Month
-1)
%3)).ToString("yyyy-MM-01");DateTime.Parse(DateTime.Now.AddMonths(6
-((DateTime.Now.Month
-1)
%3)).ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();//上季度
DateTime.Now.AddMonths(-3
-((DateTime.Now.Month
-1)
%3)).AddDays(1
-DateTime.Now);DateTime.Now.AddMonths(0
-((DateTime.Now.Month
-1)
%3)).AddDays(1
-DateTime.Now.Day).AddDays(-1).ToShortDateString();DateTimedt
=DateTime.Now;//当前时间
DateTimestartWeek=dt.AddDays(1
-Convert.ToInt32(dt.DayOfWeek.ToString("d")));//本周周一
DateTimeendWeek
=startWeek.AddDays(6);//本周周日
DateTimestartMonth=dt.AddDays(1
-dt.Day);//本月月初
DateTimeendMonth
=startMonth.AddMonths(1).AddDays(-1);//本月月末
//DateTimeendMonth=startMonth.AddDays((dt.AddMonths(1)-dt).Days-1);//本月月末
DateTimestartQuarter=dt.AddMonths(0
-(dt.Month
-1)
%3).AddDays(1
-dt.Day);//本季度初
DateTimeendQuarter
=startQuarter.AddMonths(3).AddDays(-1);//本季度末
DateTimestartYear=
newDateTime(dt.Year,1,1);//本年年初
DateTimeendYear
=newDateTime(dt.Year,12,31);//本年年末
至于昨天、明天、上周、上月、上季度、上年度等等,只要AddDays()、AddMonths()、AddYears()这几种方法组合一下就可以了。
C#中datetime的使用
//如果你还不明白,再看一下中文显示星期几的方法就应该懂了
//由于DayOfWeek返回的是数字的星期几,我们要把它转换成汉字方便我们阅读,有些人可能会用switch来一个一个地对照,其实不用那么麻烦的
string[]Day
=new
string[]{"星期日","星期一","星期二","星期三","星期四","星期五","星期六"};
stringweek
=Day[Convert.ToInt32(DateTime.Now.DayOfWeek.ToString("d"))].ToString();//上周,同理,一个周是7天,上周就是本周再减去7天,下周也是一样
DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))-7);//上周一
DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))-7).AddDays(6);//上周末(星期日)
//下周
DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))+7);//下周一
DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))+7).AddDays(6);//下周末
//本月,很多人都会说本月的第一天嘛肯定是1号,最后一天就是下个月一号再减一天。当然这是对的
//一般的写法
DateTime.Now.Year.ToString()
+DateTime.Now.Month.ToString()
+"1";//第一天
DateTime.Parse(DateTime.Now.Year.ToString()
+DateTime.Now.Month.ToString()
+"1").AddMonths(1).AddDays(-1).ToShortDateString();//最后一天
//巧用C#里ToString的字符格式化更简便
DateTime.Now.ToString("yyyy-MM-01");DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(1).AddDays(-1).ToShortDateString();//上个月,减去一个月份
DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(-1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();//下个月,加去一个月份
DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(2).AddDays(-1).ToShortDateString();//7天后
DateTime.Now.Date.ToShortDateString();DateTime.Now.AddDays(7).ToShortDateString();//7天前
DateTime.Now.AddDays(-7).ToShortDateString();DateTime.Now.Date.ToShortDateString();//本年度,用ToString的字符格式化我们也很容易地算出本年度的第一天和最后一天
DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(1).AddDays(-1).ToShortDateString();//上年度,不用再解释了吧
DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(-1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddDays(-1).ToShortDateString();//下年度
DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(2).AddDays(-1).ToShortDateString();//本季度,很多人都会觉得这里难点,需要写个长长的过程来判断。其实不用的,我们都知道一年四个季度,一个季度三个月
//首先我们先把日期推到本季度第一个月,然后这个月的第一天就是本季度的第一天了
DateTime.Now.AddMonths(0
-((DateTime.Now.Month
-1)
%3)).AddDays(1
-DateTime.Now.Day);//同理,本季度的最后一天就是下季度的第一天减一
DateTime.Parse(DateTime.Now.AddMonths(3
-((DateTime.Now.Month
-1)
%3)).ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();//下季度,相信你们都知道了。。。。收工
DateTime.Now.AddMonths(3
-((DateTime.Now.Month
-1)
%3)).ToString("yyyy-MM-01");DateTime.Parse(DateTime.Now.AddMonths(6
-((DateTime.Now.Month
-1)
%3)).ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();//上季度
DateTime.Now.AddMonths(-3
-((DateTime.Now.Month
-1)
%3)).AddDays(1
-DateTime.Now);DateTime.Now.AddMonths(0
-((DateTime.Now.Month
-1)
%3)).AddDays(1
-DateTime.Now.Day).AddDays(-1).ToShortDateString();这篇文章旨在与园友分享我对Exception的理解,如果存在不足的地方欢迎您指出。
前不久写过一篇MVC的Exception的文章,这回重点讲解在实际开发中我对Exception的认识。
讲到Exception难免会涉及到经典的代码try..catch...finally..至于一些基本概念:这个代码块的执行方式、多catch的异常捕获顺序、exception的继承。这些不是本篇讨论的重点,但这不并代表基本概念不重要。(:
建立Exception时建议日常开发中需要注意以下几点:
一、Thrownewexception
曾经看过有人在简单的函数内疯狂的使用thrownew参与业务逻辑。比如,以下代码:
逻辑类似以上代码,就是一个单一的函数,每当我看到这样的单一函数,总是觉得很奇怪。或许是自身水平有限,似乎难以理解为了catch住一个exception对象需要那么大费周章的去thrownew么?个人认为如果某方法内嵌套的方法根据业务逻辑主动抛出异常,让外层方法截获到这个异常,此时被嵌套的方法方可使用thrownew....
二、抛出不该抛出的Exception
上文中的DoSomeThing函数如果在catch时不进一步封装,直接把Excepiton抛到UI层,又或者直接显示给客户。如果异常堆栈中提示某些敏感数据。比如SQL查询语句、WebService
URI或POST信息等。这些敏感信息应该永远不让客户知道,暴露出这些信息有可能对系统造成潜在安全隐患!
三、更好的利用Exception
在实际的开发中,既然抛出了Exception那么我们应该为Exception提供尽可能多的关于异常本身的有用信息。如何为抛出的异常提供更多的有用信息呢?请看以下代码:
注释已经给的很清晰了,目的就是尽可能的提供与异常相关的有用信息,方便日后异常出现时便于调试。
ExecuteCommand方法调用如下:
类似以上机制,如果异常出现了,我认为可以大大减少debug的时间。
最后希望本篇文章可以给您带来帮助,如有不足之处欢迎指出,谢谢!
=DateTime.Now;//当前时间
DateTimestartWeek=dt.AddDays(1
-Convert.ToInt32(dt.DayOfWeek.ToString("d")));//本周周一
DateTimeendWeek
=startWeek.AddDays(6);//本周周日
DateTimestartMonth=dt.AddDays(1
-dt.Day);//本月月初
DateTimeendMonth
=startMonth.AddMonths(1).AddDays(-1);//本月月末
//DateTimeendMonth=startMonth.AddDays((dt.AddMonths(1)-dt).Days-1);//本月月末
DateTimestartQuarter=dt.AddMonths(0
-(dt.Month
-1)
%3).AddDays(1
-dt.Day);//本季度初
DateTimeendQuarter
=startQuarter.AddMonths(3).AddDays(-1);//本季度末
DateTimestartYear=
newDateTime(dt.Year,1,1);//本年年初
DateTimeendYear
=newDateTime(dt.Year,12,31);//本年年末
至于昨天、明天、上周、上月、上季度、上年度等等,只要AddDays()、AddMonths()、AddYears()这几种方法组合一下就可以了。
C#中datetime的使用
//如果你还不明白,再看一下中文显示星期几的方法就应该懂了
//由于DayOfWeek返回的是数字的星期几,我们要把它转换成汉字方便我们阅读,有些人可能会用switch来一个一个地对照,其实不用那么麻烦的
string[]Day
=new
string[]{"星期日","星期一","星期二","星期三","星期四","星期五","星期六"};
stringweek
=Day[Convert.ToInt32(DateTime.Now.DayOfWeek.ToString("d"))].ToString();//上周,同理,一个周是7天,上周就是本周再减去7天,下周也是一样
DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))-7);//上周一
DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))-7).AddDays(6);//上周末(星期日)
//下周
DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))+7);//下周一
DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))+7).AddDays(6);//下周末
//本月,很多人都会说本月的第一天嘛肯定是1号,最后一天就是下个月一号再减一天。当然这是对的
//一般的写法
DateTime.Now.Year.ToString()
+DateTime.Now.Month.ToString()
+"1";//第一天
DateTime.Parse(DateTime.Now.Year.ToString()
+DateTime.Now.Month.ToString()
+"1").AddMonths(1).AddDays(-1).ToShortDateString();//最后一天
//巧用C#里ToString的字符格式化更简便
DateTime.Now.ToString("yyyy-MM-01");DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(1).AddDays(-1).ToShortDateString();//上个月,减去一个月份
DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(-1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();//下个月,加去一个月份
DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(2).AddDays(-1).ToShortDateString();//7天后
DateTime.Now.Date.ToShortDateString();DateTime.Now.AddDays(7).ToShortDateString();//7天前
DateTime.Now.AddDays(-7).ToShortDateString();DateTime.Now.Date.ToShortDateString();//本年度,用ToString的字符格式化我们也很容易地算出本年度的第一天和最后一天
DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(1).AddDays(-1).ToShortDateString();//上年度,不用再解释了吧
DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(-1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddDays(-1).ToShortDateString();//下年度
DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(2).AddDays(-1).ToShortDateString();//本季度,很多人都会觉得这里难点,需要写个长长的过程来判断。其实不用的,我们都知道一年四个季度,一个季度三个月
//首先我们先把日期推到本季度第一个月,然后这个月的第一天就是本季度的第一天了
DateTime.Now.AddMonths(0
-((DateTime.Now.Month
-1)
%3)).AddDays(1
-DateTime.Now.Day);//同理,本季度的最后一天就是下季度的第一天减一
DateTime.Parse(DateTime.Now.AddMonths(3
-((DateTime.Now.Month
-1)
%3)).ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();//下季度,相信你们都知道了。。。。收工
DateTime.Now.AddMonths(3
-((DateTime.Now.Month
-1)
%3)).ToString("yyyy-MM-01");DateTime.Parse(DateTime.Now.AddMonths(6
-((DateTime.Now.Month
-1)
%3)).ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();//上季度
DateTime.Now.AddMonths(-3
-((DateTime.Now.Month
-1)
%3)).AddDays(1
-DateTime.Now);DateTime.Now.AddMonths(0
-((DateTime.Now.Month
-1)
%3)).AddDays(1
-DateTime.Now.Day).AddDays(-1).ToShortDateString();DateTimedt
=DateTime.Now;//当前时间
DateTimestartWeek=dt.AddDays(1
-Convert.ToInt32(dt.DayOfWeek.ToString("d")));//本周周一
DateTimeendWeek
=startWeek.AddDays(6);//本周周日
DateTimestartMonth=dt.AddDays(1
-dt.Day);//本月月初
DateTimeendMonth
=startMonth.AddMonths(1).AddDays(-1);//本月月末
//DateTimeendMonth=startMonth.AddDays((dt.AddMonths(1)-dt).Days-1);//本月月末
DateTimestartQuarter=dt.AddMonths(0
-(dt.Month
-1)
%3).AddDays(1
-dt.Day);//本季度初
DateTimeendQuarter
=startQuarter.AddMonths(3).AddDays(-1);//本季度末
DateTimestartYear=
newDateTime(dt.Year,1,1);//本年年初
DateTimeendYear
=newDateTime(dt.Year,12,31);//本年年末
至于昨天、明天、上周、上月、上季度、上年度等等,只要AddDays()、AddMonths()、AddYears()这几种方法组合一下就可以了。
C#中datetime的使用
//如果你还不明白,再看一下中文显示星期几的方法就应该懂了
//由于DayOfWeek返回的是数字的星期几,我们要把它转换成汉字方便我们阅读,有些人可能会用switch来一个一个地对照,其实不用那么麻烦的
string[]Day
=new
string[]{"星期日","星期一","星期二","星期三","星期四","星期五","星期六"};
stringweek
=Day[Convert.ToInt32(DateTime.Now.DayOfWeek.ToString("d"))].ToString();//上周,同理,一个周是7天,上周就是本周再减去7天,下周也是一样
DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))-7);//上周一
DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))-7).AddDays(6);//上周末(星期日)
//下周
DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))+7);//下周一
DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))+7).AddDays(6);//下周末
//本月,很多人都会说本月的第一天嘛肯定是1号,最后一天就是下个月一号再减一天。当然这是对的
//一般的写法
DateTime.Now.Year.ToString()
+DateTime.Now.Month.ToString()
+"1";//第一天
DateTime.Parse(DateTime.Now.Year.ToString()
+DateTime.Now.Month.ToString()
+"1").AddMonths(1).AddDays(-1).ToShortDateString();//最后一天
//巧用C#里ToString的字符格式化更简便
DateTime.Now.ToString("yyyy-MM-01");DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(1).AddDays(-1).ToShortDateString();//上个月,减去一个月份
DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(-1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();//下个月,加去一个月份
DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(2).AddDays(-1).ToShortDateString();//7天后
DateTime.Now.Date.ToShortDateString();DateTime.Now.AddDays(7).ToShortDateString();//7天前
DateTime.Now.AddDays(-7).ToShortDateString();DateTime.Now.Date.ToShortDateString();//本年度,用ToString的字符格式化我们也很容易地算出本年度的第一天和最后一天
DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(1).AddDays(-1).ToShortDateString();//上年度,不用再解释了吧
DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(-1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddDays(-1).ToShortDateString();//下年度
DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(2).AddDays(-1).ToShortDateString();//本季度,很多人都会觉得这里难点,需要写个长长的过程来判断。其实不用的,我们都知道一年四个季度,一个季度三个月
//首先我们先把日期推到本季度第一个月,然后这个月的第一天就是本季度的第一天了
DateTime.Now.AddMonths(0
-((DateTime.Now.Month
-1)
%3)).AddDays(1
-DateTime.Now.Day);//同理,本季度的最后一天就是下季度的第一天减一
DateTime.Parse(DateTime.Now.AddMonths(3
-((DateTime.Now.Month
-1)
%3)).ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();//下季度,相信你们都知道了。。。。收工
DateTime.Now.AddMonths(3
-((DateTime.Now.Month
-1)
%3)).ToString("yyyy-MM-01");DateTime.Parse(DateTime.Now.AddMonths(6
-((DateTime.Now.Month
-1)
%3)).ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();//上季度
DateTime.Now.AddMonths(-3
-((DateTime.Now.Month
-1)
%3)).AddDays(1
-DateTime.Now);DateTime.Now.AddMonths(0
-((DateTime.Now.Month
-1)
%3)).AddDays(1
-DateTime.Now.Day).AddDays(-1).ToShortDateString();这篇文章旨在与园友分享我对Exception的理解,如果存在不足的地方欢迎您指出。
前不久写过一篇MVC的
讲到Exception难免会涉及到经典的代码try..catch...finally..至于一些基本概念:这个代码块的执行方式、多catch的异常捕获顺序、exception的继承。这些不是本篇讨论的重点,但这不并代表基本概念不重要。(:
建立Exception时建议日常开发中需要注意以下几点:
一、Thrownewexception
曾经看过有人在简单的函数内疯狂的使用thrownew参与业务逻辑。比如,以下代码:
01 | public object DoSomeThing( string userName) |
02 | { |
03 | try |
04 | { |
05 | if (String.IsNullOrEmpty(userName)) |
06 | { |
07 | throw new Exception( "用户名不能为空" ); |
08 | } |
09 | } |
10 | catch (Exceptionex) |
11 | { |
12 | return ex.Message; |
13 | } |
14 | return true ; |
15 | } |
二、抛出不该抛出的Exception
上文中的DoSomeThing函数如果在catch时不进一步封装,直接把Excepiton抛到UI层,又或者直接显示给客户。如果异常堆栈中提示某些敏感数据。比如SQL查询语句、WebService
URI或POST信息等。这些敏感信息应该永远不让客户知道,暴露出这些信息有可能对系统造成潜在安全隐患!
三、更好的利用Exception
在实际的开发中,既然抛出了Exception那么我们应该为Exception提供尽可能多的关于异常本身的有用信息。如何为抛出的异常提供更多的有用信息呢?请看以下代码:
01 | public static void
ref string errMsg) |
02 | { |
03 | using (varconnection= new SqlConnection( "数据库连接字符串" )) |
04 | { |
05 | varcmd=connection.CreateCommand(); |
06 | try |
07 | { |
08 | action(cmd); |
09 | cmd.ExecuteNonQuery(); |
10 | } |
11 | catch (DbExceptionex) //注意这里将DbExceptioncatch住 |
12 | { |
13 | errMsg=ex.Message; |
14 | varparameters= new Dictionary< string , object >(); |
15 | foreach (SqlParameterp in cmd.Parameters) |
16 | parameters.Add(p.ParameterName,p.Value); |
17 |
18 | //尽可能获取与exception相关的有用信息,这里只是用SqlParameter举例而已。 |
19 |
20 | //TODO:(将parameters与ex对象保存或者进一步处理) |
21 |
22 | } |
23 | catch (Exceptionex) |
24 | { |
25 | //TODO其他的异常处理 |
26 | } |
27 | finally |
28 | { |
29 | cmd.Dispose(); |
30 | } |
31 | } |
32 | } |
ExecuteCommand方法调用如下:
01 | static void Main( string []args) |
02 | { |
03 | string errMsg= string .Empty; |
04 | ExecuteCommand(cmd=> |
05 | { |
06 | cmd.CommandText= "UPDATEuserSETname=@nameWHEREid=@id" ; |
07 | cmd.Parameters.Add( new SqlParameter( "name" , "字符串参数值" )); |
08 | cmd.Parameters.Add( new SqlParameter( "id" ,1)); |
09 | }, ref errMsg); |
10 |
11 | } |
最后希望本篇文章可以给您带来帮助,如有不足之处欢迎指出,谢谢!
相关文章推荐
- 转: C# 根据当前时间获取,本周,本月,本季度等时间段 .Net中Exception
- C# 根据当前时间获取,本周,本月,本季度等时间段 .Net中Exception
- C# 根据当前时间获取,本周,本月,本季度等时间段
- c# 根据当前时间获取,本周,本月,本季度,月初,月末,各个时间段
- c# DateTime根据当前时间获取,本周,本月,本季度,月初,月末,各个时间段
- 转:c# 根据当前时间获取,本周,本月,本季度,月初,月末,各个时间段
- C# 根据当前时间获取,本周,本月,本季度等时间段
- C#根据当前时间获取,本周,本月,本季度等时间段
- c# 根据当前时间获取,本周,本月,本季度,月初,月末,各个时间段(转但是都是使用过)
- 转:c# 根据当前时间获取,本周,本月,本季度,月初,月末,各个时间段
- c# 根据当前时间获取,本周,本月,本季度,月初,月末,各个时间段
- C# 根据当前时间获取,本周,本月,本季度等时间段
- C# 根据当前时间获取,本周,本月,本季度,月初,月末,各个时间段
- c# 根据当前时间获取,本周,本月,本季度,月初,月末,各个时间段
- C# 根据当前时间获取,本周,本月,本季度等时间段
- c# 根据当前时间获取,本周,本月,本季度,月初,月末,各个时间段
- c# 根据当前时间获取,本周,本月,本季度,月初,月末,各个时间段
- C# 根据当前时间获取,本周,本月,本季度等时间段
- c# 根据当前时间获取,本周,本月,本季度,月初,月末,各个时间段
- c# 根据当前时间获取,本周,本月,本季度,月初,月末,各个时间段