博客
关于我
Java 中的 try catch 影响性能吗?
阅读量:416 次
发布时间:2019-03-06

本文共 1199 字,大约阅读时间需要 3 分钟。

前几日在一次代码审查中发现了一段代码中存在过度使用try-catch的情况。这种现象或许我们都经历过,初入职场时为了避免程序崩溃,会不自觉地在很多地方加try-catch。然而,这种做法不仅让代码变得难以阅读,还对程序性能产生了负面影响。有人可能会觉得,try-catch看起来不过是一种异常处理机制,何必担心它对性能有什么影响呢?于是我们来做了一些实验来测试一下。

在未使用try-catch的情况下,执行100万次加法的耗时是多少呢?我们可以通过以下代码来测试:

long start = System.nanoTime();int a = 0;for (int i = 0; i < 1000000; i++) {    a++;}System.out.println(System.nanoTime() - start);

经过5次测试,平均耗时约为1816048纳秒,即1.8毫秒。

接下来,我们来看在使用了try-catch但没有抛出异常的情况下,执行100万次加法的耗时是多少:

long start = System.nanoTime();int a = 0;for (int i = 0; i < 1000000; i++) {    try {        a++;    } catch (Exception e) {        e.printStackTrace();    }}System.out.println(System.nanoTime() - start);

同样进行了5次测试,平均耗时约为1928394纳秒,即1.9毫秒。

再来看如果在try-catch中抛出了异常,执行100万次加法的耗时是多少:

long start = System.nanoTime();int a = 0;for (int i = 0; i < 1000000; i++) {    try {        a++;        throw new Exception();    } catch (Exception e) {        e.printStackTrace();    }}System.out.println(System.nanoTime() - start);

经过5次测试,平均耗时约为780950471纳秒,即780毫秒。

通过这三次测试,我们可以得出一个结论:在没有抛出异常的情况下,使用try-catch对程序的性能影响几乎可以忽略不计。然而,一旦在try-catch中抛出了异常,那对程序的性能影响就会变得非常明显,甚至会导致性能损失数百倍。

因此,在实际编程中,我们需要特别注意try-catch语句的使用,尽量避免在不必要的地方过度使用。只有在确实需要处理异常时,才应该使用try-catch,以确保代码的健壮性和性能的优化。

转载地址:http://tnakz.baihongyu.com/

你可能感兴趣的文章
Opacity多浏览器透明度兼容处理
查看>>
OPC在工控上位机中的应用
查看>>
VSCode在终端中使用yarn命令
查看>>
OPEN CASCADE Curve Continuity
查看>>
Open Graph Protocol(开放内容协议)
查看>>
Open vSwitch实验常用命令
查看>>
Open WebUI 忘了登入密码怎么办?
查看>>
open***负载均衡高可用多种方案实战讲解02(老男孩主讲)
查看>>
Open-E DSS V7 应用系列之五 构建软件NAS
查看>>
Open-Sora代码详细解读(1):解读DiT结构
查看>>
Open-Sora代码详细解读(2):时空3D VAE
查看>>
Open-Source Service Discovery
查看>>
open-vm-tools-dkms : 依赖: open-vm-tools (>= 2:9.4.0-1280544-5ubuntu3) 但是它将不会被安装
查看>>
open3d-Dll缺失,未找到指定模块解决
查看>>
openai Midjourney代理服务 gpt大模型第三方api平台汇总 支持国内外各种大模型 持续更新中...
查看>>
OpenAll:Android打开组件新姿势【仅供用于学习了解ButterKnife框架基本原理】
查看>>
OpenASR 项目使用教程
查看>>
Openbox-桌面图标设置
查看>>
opencart出现no such file or dictionary
查看>>
OpenCV 3.1 imwrite()函数写入异常问题解决方法
查看>>