众所周知,try/catch在C编程中是用来处理异常的,但是,你知道吗,try/catch还有一个更加广泛应用的妙用。
由于本人不善言辞,在此还是以实例说明。下面的程序是要执行网络通/不通的情况下,程序执行不同的语句。
try
{
sc.Open();
this.check();
sc.Close();
}
catch(Exception ex)
{
this.textBox1.Text="无法显示";
}
private void check()
{
DateTime time=Convert.ToDateTime(DateTime.Now.ToShortDateString());
if(sc.State==ConnectionState.Closed)
{
sc.Open();
}
SqlCommand scmd=new SqlCommand("select teacherID ,coursename ,type ,sname from arrangelist where sdate='"+time+"' and jieci='"+this.textBox2.Text+"' and roomID='"+room.roomid()+"' ",sc);
SqlDataReader sdr=scmd.ExecuteReader();
while(sdr.Read())
{
this.textBox1.Text=sdr["type"].ToString();
}
sdr.Close();
sc.Close();
}
在此例中我们无需知道方法check的目的是要做什么,只需要注意到在方法check中,有sc.Open();来打开数据库连接。
而我们必须注意到,在网络不通的情况下,如果没有try/catch 的话,那么顺序执行的效果将是报出异常“数据库连接
失败”,在这里,try/catch起到的效果就是不抛出异常,在try{}里面的内容不能执行的情况下,直接执行catch语句中
的内容。