zoukankan      html  css  js  c++  java
  • trycatch 与 Response.End()

      

        测试代码如下: (asp.net2.0 +windows2008)
    //***********************************//

        protected void Button1_Click(object sender, EventArgs e)
        {
            try
            {
                DoSomething();
            }
            catch (Exception ex)
            {
                WriteErr("Out:" + ex.Message);
            }

        }
        private void DoSomething()
        {
            try
            {
                DoSomethingIn();

            }
            catch (Exception ex)
            {
                WriteErr("Inner:" + ex.Message);

            }
        }
        private void DoSomethingIn()
        {
            try
            {
                Response.End();

            }
            catch (Exception ex)
            {
                WriteErr("Inner-Inner:" + ex.Message);
            }
        }

    //********************End******************//

    输出结果:

    Inner-Inner:正在中止线程。
    Inner:正在中止线程。
    Out:正在中止线程。

    表明使用Response.End()后,抛出的错误会一直顺着函数调用栈向下传递(被调用函数到调用函数),即使加了错误处理也照样传递.

    基于以上事实看如下代码:

    //*************************************//

       protected void Button1_Click(object sender, EventArgs e)
        {
            try
            {
                DoSomething();
                DoAnother();
            }
            catch (Exception ex)
            {
                WriteErr("Out:" + ex.Message);
            }

        }
        private void DoSomething()
        {
            try
            {
                throw new Exception("一个错误!");

            }
            catch (Exception ex)
            {
                //用意:输出错误后结束页面
                WriteErr(ex.Message);
                Response.End();
            }
           
        }

    //********************End***************
    上面DoSomething的用意是,在这个处理过程中遇到错误后,向用户提示一段错误信息然后结束页面输出,但因为在catch中使用了Response.End(),最后的结果是输出了两个错误提示信息.

     针对上面的情况,可以将DoSothing里的错误处理过程去调,而是抛出一个自定义错误,在最外面的过程中(一般用户触发的事件处理过程)捕获并做相应处理.

  • 相关阅读:
    Serverless 的初心、现状和未来
    父亲的茶杯
    子慕谈设计模式系列(三)
    子慕谈设计模式系列(二)——设计模式六大原则
    子慕谈设计模式系列(一)
    初入angular4——实际项目搭建总结
    欲练JS,必先攻CSS——前端修行之路
    运用google-protobuf的IM消息应用开发(前端篇)
    “倔驴”一个h5小游戏的实现和思考(码易直播)——总结与整理
    【猿分享第10期】微信小程序Meetup扫盲专场回顾(转载)
  • 原文地址:https://www.cnblogs.com/wdfrog/p/1595032.html
Copyright © 2011-2022 走看看