• php Try Catch多层级异常测试


    <?php
    class a {
     public function a1 () {
      try {
       throw new Exception('123');
      } catch (Exception $e) {
       throw $e;
      }
     }
    }
    
    class b {
     public function b1 () {
      try {
       $a = new a();
       $a->a1();
      } catch (Exception $e) {
       throw $e;
       //throw new Exception($e->getMessage());
      }
     }
    }
    
    class c {
     public function c1 () {
      try {
       $a = new b();
       $a->b1();
      } catch (Exception $e) {
       throw $e;
      }
     }
    }
    
    try {
     $c = new c();
      $c->c1();
    } catch (Exception $e) {
     echo $e->getTraceAsString();
    }
    echo 'end';
    
    ?>

    页面try catch里使用c的 c1,c1里使用b的b1,b1里使用a的a1。

    默认的是:a1里抛出异常,b1里捕获a1的异常,然后再把刚才的异常抛出,c1捕获,然后抛出,最后页面捕获并输出。
    结果是:
    X-Powered-By: PHP/5.1.1
    Content-type: text/html

    #0 D:workspacemyzCollection est.php(16): a->a1()
    #1 D:workspacemyzCollection est.php(28): b->b1()
    #2 D:workspacemyzCollection est.php(37): c->c1()
    #3 C:Program FilesendendStudio-5.2.0inphp5dummy.php(1): include('D:workspacemy...')
    #4 {main}end


     

    第二个测试:
    把b1里面的throw $e去掉,就是不抛出。
    结果是:
    X-Powered-By: PHP/5.1.1
    Content-type: text/html

    end


     

    第三个测试:
    把b1里面的throw new Exception($e->getMessage());打开。
    抛出一个新的异常,这样b1以上的调用都拿不到a1的异常了。
    结果是:
    X-Powered-By: PHP/5.1.1
    Content-type: text/html

    #0 D:workspacemyzCollection est.php(28): b->b1()
    #1 D:workspacemyzCollection est.php(37): c->c1()
    #2 C:Program FilesendendStudio-5.2.0inphp5dummy.php(1): include('D:workspacemy...')
    #3 {main}end


     

    第四个测试:
    把b1里面的try catch throw都去掉。
    结果:仍然输出原来的异常,就是说中间的步骤不需要抛出,最上层也能拿到最下层抛出的异常。
    只是有一个问题,b中如果出先异常,就没有办法取到,如果需要也检测b的话,那么也要在b中加上try catch

    X-Powered-By: PHP/5.1.1
    Content-type: text/html

    #0 D:workspacemyzCollection est.php(16): a->a1()
    #1 D:workspacemyzCollection est.php(28): b->b1()
    #2 D:workspacemyzCollection est.php(37): c->c1()
    #3 C:Program FilesendendStudio-5.2.0inphp5dummy.php(1): include('D:workspacemy...')
    #4 {main}end

  • 相关阅读:
    Minecraft 1.12.2/1.14.4 Mod开发笔记——搭建环境
    Minecraft 1.12.2 Mod开发笔记
    浅谈莫比乌斯反演
    卡迈克尔数
    一些可能会有用的东西(持续更新)
    emacs配置
    CSPS 2020游记
    浅谈KMP
    Atcoder AGC052
    乌班图操作指令(持续更新)
  • 原文地址:https://www.cnblogs.com/moqiang02/p/4061375.html
Copyright © 2020-2023  润新知