try catch 应该在for循环里面还是外面?

学习改变命运,技术铸就辉煌。

大家好,我是銘,全栈开发程序员。

今天,上班的时候发现一个小问题,try catch 捕获异常的时候,代码放在 for 循环里面和外面是不一样的,现在闲下来了,就好好研究一下它俩到底有啥区别。

使用场景

首先从使用场景来看,

  1. 当 tyr catch 在 for 循环外面时,示例代码如下:
dart 复制代码
    @Test
    public void test2() {
        try {
            for (int num = 1; num <= 5; num++) {
                if (num == 3) {
                    //故意制造一下异常
                    int number = 1 / 0;
                } else {
                    System.out.println("num:" + num + " 业务正常执行");
                }
            }
        } catch (Exception e) {
            System.out.println("try catch  在for 外面的情形, 出现了异常,for循环显然被中断");
        }
    }

当出现异常时,控制台如下:

image-20240125230636350

结论:try catch 在 for 循环 外面 的时候, 如果 for循环过程中出现了异常, 那么for循环会终止

  1. try catch 在 for 循环里面时,示例代码如下:
dart 复制代码
    @Test
    public void test3() {

        for (int num = 1; num <= 5; num++) {
            try {
                if (num == 3) {
                    //故意制造一下异常
                    int number = 1 / 0;
                } else {
                    System.out.println("num:" + num + " 业务正常执行");
                }
            } catch (Exception e) {
                System.out.println("try catch在for 里面的情形,出现了异常,for循环显然继续执");
            }
        }
    }

运行代码,控制台如下:

image-20240125234619238

结论:try catch 在 for 循环 里面 的时候, 如果 for循环过程中出现了异常,异常被catch抓掉,不影响for循环 继续执行

性能

从性能上分析,当代码无异常时,时间相差并不大,内存消耗差距也不大,但是,当代码发生异常时,差距就会很明显。

我们用 Runtime 来统计一下内存消耗的情况

ini 复制代码
Runtime runtime = Runtime.getRuntime();
long memory = runtime.freeMemory();

当循环次数比较多时,业务代码比较复杂时,两者之间的时间和内存的消耗差距会非常的大。

总结

try catch 是放在 for 循环里面还是外面,就看业务的需求,如果需要出现异常就终止循环的,就放在外面,不需要终止循环的,就放在里面。

大学C语言、Java、数据结构、离散数学答案+几十本编程电子书 ,免费分享

链接:pan.baidu.com/s/1ES7FZxY-... 提取码:75ol

相关推荐
学习OK呀几秒前
日常docker的实操命令场景
后端
雾原3 分钟前
Nginx高频用途的详细配置和性能调优
后端
类似不类似3 分钟前
快速配置linux远程开发-go语言
开发语言·后端·golang
前端付豪3 分钟前
1、为什么浏览器要有渲染流程? ——带你一口气吃透 Critical Rendering Path
前端·后端·浏览器
前端付豪6 分钟前
3、Node.js异步编程彻底吃透
前端·后端·node.js
老胖闲聊7 分钟前
Flask 请求数据获取方法详解
后端·python·flask
舒一笑11 分钟前
一文简单记录打通K8s+Kibana流程如何启动(Windows下的Docker版本)
后端·elasticsearch·kibana
亦黑迷失12 分钟前
轻量级 Express 服务器:用 Pug 模板引擎实现动态参数传递
前端·javascript·后端
慧一居士21 分钟前
Kafka批量消费部分处理成功时的手动提交方案
分布式·后端·kafka
命中的缘分1 小时前
SpringCloud原理和机制
后端·spring·spring cloud