【Java】29.常用API之lang.Throwable(异常情况大总结)

本文全面解析Java中的各种异常,包括常见的运行时异常如NullPointerException、ClassCastException等,以及系统级异常如Error、ExceptionInInitializerError等,深入理解Java异常处理机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

常见的几种RuntimeException 

NullPointerException - 空指针引用异常 
ClassCastException - 类型强制转换异常。 
IllegalArgumentException - 传递非法参数异常。 
ArithmeticException - 算术运算异常 
ArrayStoreException - 向数组中存放与声明类型不兼容对象异常 
IndexOutOfBoundsException - 下标越界异常 
NegativeArraySizeException - 创建一个大小为负数的数组错误异常 
NumberFormatException - 数字格式异常 
SecurityException - 安全异常 
UnsupportedOperationException - 不支持的操作异常 


算术异常类:ArithmeticExecption 
空指针异常类:NullPointerException 
类型强制转换异常:ClassCastException 
数组负下标异常:NegativeArrayException 
数组下标越界异常:ArrayIndexOutOfBoundsException 
违背安全原则异常:SecturityException 
文件已结束异常:EOFException 
文件未找到异常:FileNotFoundException 
字符串转换为数字异常:NumberFormatException 
操作数据库异常:SQLException 
输入输出异常:IOException 
方法未找到异常:NoSuchMethodException 

java.lang.AbstractMethodError 
抽象方法错误。当应用试图调用抽象方法时抛出。 

java.lang.AssertionError 
断言错。用来指示一个断言失败的情况。 

java.lang.ClassCircularityError 
类循环依赖错误。在初始化一个类时,若检测到类之间循环依赖则抛出该异常。 

java.lang.ClassFormatError 
类格式错误。当Java虚拟机试图从一个文件中读取Java类,而检测到该文件的内容不符合类的有效格式时抛出。 

java.lang.Error 
错误。是所有错误的基类,用于标识严重的程序运行问题。这些问题通常描述一些不应被应用程序捕获的反常情况。 

java.lang.ExceptionInInitializerError 
初始化程序错误。当执行一个类的静态初始化程序的过程中,发生了异常时抛出。静态初始化程序是指直接包含于类中的static语句段。 

java.lang.IllegalAccessError 
违法访问错误。当一个应用试图访问、修改某个类的域(Field)或者调用其方法,但是又违反域或方法的可见性声明,则抛出该异常。 

java.lang.IncompatibleClassChangeError 
不兼容的类变化错误。当正在执行的方法所依赖的类定义发生了不兼容的改变时,抛出该异常。一般在修改了应用中的某些类的声明定义而没有对整个应用重新编译而直接运行的情况下,容易引发该错误。 

java.lang.InstantiationError 
实例化错误。当一个应用试图通过Java的new操作符构造一个抽象类或者接口时抛出该异常. 

java.lang.InternalError 
内部错误。用于指示Java虚拟机发生了内部错误。 

java.lang.LinkageError 
链接错误。该错误及其所有子类指示某个类依赖于另外一些类,在该类编译之后,被依赖的类改变了其类定义而没有重新编译所有的类,进而引发错误的情况。 

java.lang.NoClassDefFoundError 
未找到类定义错误。当Java虚拟机或者类装载器试图实例化某个类,而找不到该类的定义时抛出该错误。 

java.lang.NoSuchFieldError 
域不存在错误。当应用试图访问或者修改某类的某个域,而该类的定义中没有该域的定义时抛出该错误。 

java.lang.NoSuchMethodError 
方法不存在错误。当应用试图调用某类的某个方法,而该类的定义中没有该方法的定义时抛出该错误。 

java.lang.OutOfMemoryError 
内存不足错误。当可用内存不足以让Java虚拟机分配给一个对象时抛出该错误。 

java.lang.StackOverflowError 
堆栈溢出错误。当一个应用递归调用的层次太深而导致堆栈溢出时抛出该错误。 

java.lang.ThreadDeath 
线程结束。当调用Thread类的stop方法时抛出该错误,用于指示线程结束。 

java.lang.UnknownError 
未知错误。用于指示Java虚拟机发生了未知严重错误的情况。 

java.lang.UnsatisfiedLinkError 
未满足的链接错误。当Java虚拟机未找到某个类的声明为native方法的本机语言定义时抛出。 

java.lang.UnsupportedClassVersionError 
不支持的类版本错误。当Java虚拟机试图从读取某个类文件,但是发现该文件的主、次版本号不被当前Java虚拟机支持的时候,抛出该错误。 

java.lang.VerifyError 
验证错误。当验证器检测到某个类文件中存在内部不兼容或者安全问题时抛出该错误。 

java.lang.VirtualMachineError 
虚拟机错误。用于指示虚拟机被破坏或者继续执行操作所需的资源不足的情况。 

java.lang.ArithmeticException 
算术条件异常。譬如:整数除零等。 

java.lang.ArrayIndexOutOfBoundsException 
数组索引越界异常。当对数组的索引值为负数或大于等于数组大小时抛出。 

java.lang.ArrayStoreException 
数组存储异常。当向数组中存放非数组声明类型对象时抛出。 

java.lang.ClassCastException 
类造型异常。假设有类A和B(A不是B的父类或子类),O是A的实例,那么当强制将O构造为类B的实例时抛出该异常。该异常经常被称为强制类型转换异常。 

java.lang.ClassNotFoundException 
找不到类异常。当应用试图根据字符串形式的类名构造类,而在遍历CLASSPAH之后找不到对应名称的class文件时,抛出该异常。 

java.lang.CloneNotSupportedException 
不支持克隆异常。当没有实现Cloneable接口或者不支持克隆方法时,调用其clone()方法则抛出该异常。 

java.lang.EnumConstantNotPresentException 
枚举常量不存在异常。当应用试图通过名称和枚举类型访问一个枚举对象,但该枚举对象并不包含常量时,抛出该异常。 

java.lang.Exception 
根异常。用以描述应用程序希望捕获的情况。 

java.lang.IllegalAccessException 
违法的访问异常。当应用试图通过反射方式创建某个类的实例、访问该类属性、调用该类方法,而当时又无法访问类的、属性的、方法的或构造方法的定义时抛出该异常。 

java.lang.IllegalMonitorStateException 
违法的监控状态异常。当某个线程试图等待一个自己并不拥有的对象(O)的监控器或者通知其他线程等待该对象(O)的监控器时,抛出该异常。 

java.lang.IllegalStateException 
违法的状态异常。当在Java环境和应用尚未处于某个方法的合法调用状态,而调用了该方法时,抛出该异常。 

java.lang.IllegalThreadStateException 
违法的线程状态异常。当县城尚未处于某个方法的合法调用状态,而调用了该方法时,抛出异常。 

java.lang.IndexOutOfBoundsException 
索引越界异常。当访问某个序列的索引值小于0或大于等于序列大小时,抛出该异常。 

java.lang.InstantiationException 
实例化异常。当试图通过newInstance()方法创建某个类的实例,而该类是一个抽象类或接口时,抛出该异常。 

java.lang.InterruptedException 
被中止异常。当某个线程处于长时间的等待、休眠或其他暂停状态,而此时其他的线程通过Thread的interrupt方法终止该线程时抛出该异常。 

java.lang.NegativeArraySizeException 
数组大小为负值异常。当使用负数大小值创建数组时抛出该异常。 

java.lang.NoSuchFieldException 
属性不存在异常。当访问某个类的不存在的属性时抛出该异常。 

java.lang.NoSuchMethodException 
方法不存在异常。当访问某个类的不存在的方法时抛出该异常。 

java.lang.NullPointerException 
空指针异常。当应用试图在要求使用对象的地方使用了null时,抛出该异常。譬如:调用null对象的实例方法、访问null对象的属性、计算null对象的长度、使用throw语句抛出null等等。 

java.lang.NumberFormatException 
数字格式异常。当试图将一个String转换为指定的数字类型,而该字符串确不满足数字类型要求的格式时,抛出该异常。 

java.lang.RuntimeException 
运行时异常。是所有Java虚拟机正常操作期间可以被抛出的异常的父类。 

java.lang.SecurityException 
安全异常。由安全管理器抛出,用于指示违反安全情况的异常。 

java.lang.StringIndexOutOfBoundsException 
字符串索引越界异常。当使用索引值访问某个字符串中的字符,而该索引值小于0或大于等于序列大小时,抛出该异常。 

java.lang.TypeNotPresentException 
类型不存在异常。当应用试图以某个类型名称的字符串表达方式访问该类型,但是根据给定的名称又找不到该类型是抛出该异常。该异常与ClassNotFoundException的区别在于该异常是unchecked(不被检查)异常,而ClassNotFoundException是checked(被检查)异常。 

java.lang.UnsupportedOperationException 
不支持的方法异常。指明请求的方法不被支持情况的异常。 

<think>好的,我现在需要处理用户关于JankFactorTracker中出现的java.lang.Throwable异常的问题。首先,我需要明确用户的具体情况。用户提到在使用Android应用程序时遇到了这个异常,特别是在涉及SQLite数据库操作之后。虽然应用没有崩溃,但用户希望找到解决方案。 根据用户提供的引用内容,特别是引用[4]和[5],问题可能与资源未正确释放有关。比如数据库连接、游标或流没有关闭,导致资源泄漏。引用[5]提到,资源在获取后未被释放,建议检查Closeable接口的使用情况。 接下来,我需要思考JankFactorTracker可能是什么。Jank通常指应用中的卡顿现象,JankFactorTracker可能是用来监测和分析应用性能卡顿的工具或模块。出现Throwable异常可能是在跟踪过程中发生了错误,但被捕获而未导致崩溃,所以用户需要排查潜在的资源管理问题。 解决方案方面,首先应检查代码中所有资源的使用,尤其是数据库操作部分。确保Cursor、SQLiteDatabase和InputStream等资源在使用后及时关闭,最好使用try-with-resources语句(在Java 7及以上)或在finally块中手动关闭。同时,检查是否有异常被捕获但未正确处理,导致资源未释放。使用StrictMode可以帮助检测资源泄漏,例如在应用启动时启用StrictMode,设置检测策略为探测磁盘和网络操作,并观察日志中的警告信息。 另外,用户可能需要检查JankFactorTracker本身的实现是否存在问题,比如是否有内存泄漏或未处理的异常。更新相关依赖库或查看是否有已知的bug修复版本也是必要的。如果问题依旧,建议用户提供更详细的堆栈跟踪信息,以便进一步分析具体原因。 最后,根据引用[1]和[3],Throwable是所有异常和错误的父类,因此需要区分是Error还是Exception的子类。如果是Error,可能涉及更严重的系统问题,而Exception则更多是应用层面的异常,需要不同的处理策略。</think>### JankFactorTracker中java.lang.Throwable异常处理解决方案 #### 1. 异常背景分析 `JankFactorTracker`通常用于Android性能监控(如卡顿检测),当出现`java.lang.Throwable`异常时,可能涉及以下原因: - **资源未释放**:数据库连接、游标(Cursor)或文件流未关闭[^4][^5] - **异步任务泄漏**:未正确取消或释放异步线程 - **监控工具自身缺陷**:JankFactorTracker的代码逻辑问题或兼容性问题 --- #### 2. 分步解决方案 **步骤1:检查资源释放** ```java // 示例:数据库操作必须显式关闭Cursor和Database try (SQLiteDatabase db = helper.getReadableDatabase(); Cursor cursor = db.query(...)) { // 业务逻辑 } catch (Throwable t) { Log.e("JankTracker", "Resource error", t); } ``` - 使用`try-with-resources`自动关闭资源(API 18+支持) - 手动关闭需在`finally`块中确保执行 --- **步骤2:排查异步任务** ```java // 若使用Handler或Thread,需在onDestroy()中清理 @Override protected void onDestroy() { handler.removeCallbacksAndMessages(null); asyncTask.cancel(true); super.onDestroy(); } ``` - 避免匿名内部类持有外部类引用导致内存泄漏 --- **步骤3:启用StrictMode检测** ```java // 在Application.onCreate()中添加 if (BuildConfig.DEBUG) { StrictMode.setThreadPolicy(new StrictMode.ThreadPolicy.Builder() .detectAll() .penaltyLog() .build()); } ``` - 通过日志定位未释放资源的具体位置 --- **步骤4:分析堆栈轨迹** - 过滤日志中`JankFactorTracker`相关的堆栈信息 - 重点关注以下关键字: ``` android.database.CursorWindow java.io.Closeable SQLiteClosable.finalize() ``` --- **步骤5:更新依赖库** - 检查`JankFactorTracker`库版本 - 升级到最新版(可能已修复已知异常) --- #### 3. 典型错误场景 | 场景 | 解决方案 | |------|----------| | 数据库游标泄漏 | 使用`Matrix-CursorTrace`等工具检测 | | 内存不足导致跟踪失败 | 优化内存使用,增加OOM监控 | | 第三方库兼容性问题 | 隔离监控代码到独立进程 | --- #### 引用验证 上述方案基于Throwable异常的通用处理原则[^1][^3],特别是资源释放规范[^5]。建议结合具体堆栈信息细化处理措施。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值