Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 771|回复: 0

java外部捕获了异常,但是并没有打印异常和将异常信息写入日志文件

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-6-19 19:32:46 | 显示全部楼层 |阅读模式

    问题描述

    今天在做一个客户需求的二次开发,出现了一个java数组越界但是并没有抛异常,也没有写日志的情况。在公司的系统中,用户提交的表单可能包含有多个明细表。用户提交表单以后可以通过多个Action进行后续的数据校验,数据同步到异构系统等,可根据用户的需求进行灵活的开发。DetailTable[] detailTables = request.getDetails();通过这种方法就可以获取到表单中的所有明细表,然后通过明细表索引来获取。写了大致如下的一个类,结果自己测试的时候发现一直没有正确的结果,查看日志也并没有什么相关的异常信息,通过debug排查之后才发现是数组越界的问题,但是系统调用(我们开发人员写好Action类,然后通过系统后台配置就可以使用这个Action了)的时候在外层捕获了异常,并且没有打印异常,也没有将异常写进日志中去。这个问题挺隐秘的,前人挖的坑啊。

    class MyAction implements Action {
    
    	@Override
    	public String execute(Request request) {
    		DetailTable[] detailTables = request.getDetails();
    		int index = 3;
    		doSomething(detailTables[index]);
    		return SUCCESS;
    	}
    
    	public void doSomething(DetailTable detailTable) {
    
    	}
    
    }
    

    原因

    外层捕获异常,但是并没有打印异常或者写进日志文件。

    public class App {
    	public static void main(String[] args) {
    		MyAction action = new MyAction();
    		String back = Action.SUCCESS;
    		try {
    			back = action.execute();
    		} catch (Exception e) {
    		}
    		System.out.println(back);
    	}
    }
    
    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-2-2 00:44 , Processed in 0.069465 second(s), 30 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表