「java反射异常属于什么」java反射的弊端
本篇文章给大家谈谈java反射异常属于什么,以及java反射的弊端对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
本文目录一览:
- 1、求助,java.lang.NoSuchFieldError这是什么原因
- 2、JAVA中IllegalAccessException异常
- 3、JAVA反射为什么总要异常处理?
- 4、java反射机制详解
- 5、JAVA中反射是什么
求助,java.lang.NoSuchFieldError这是什么原因
NoSuchFieldError是Java反射中的一个异常,其表示无法通过反射找到需要的字段。应该是字段没有一致,检查大小写看看。
JAVA中IllegalAccessException异常
Sample类在com.sxy.jvm包下,但构造函数的权限不是public。权限限定符有问题,应该在Sample()前加public。
package com.sxy.jvm;public class Sample{
private string name;之前没有public所以报错
publicd Sample(){//public vs 不写
system.out.println("Sample is loaded by"+this.getClass().getClassLoader());new Child();
}
方法名前不写:同一个包下的不能被访问。
方法名前写public:同一个包下的可以访问到。
扩展资料:
Java反射用途:
在日常的第三方应用开发过程中,经常会遇到某个类的某个成员变量、方法或是属性是私有的或是只对系统应用开放,这时候就可以利用Java的反射机制通过反射来获取所需的私有成员或是方法。当然,也不是所有的都适合反射,之前就遇到一个案例。
通过反射得到的结果与预期不符。阅读源码发现,经过层层调用后在最终返回结果的地方对应用的权限进行了校验,对于没有权限的应用返回值是没有意义的缺省值,否则返回实际值起到保护用户的隐私目的。
JAVA反射为什么总要异常处理?
JAVA中的异常和反射
一、异常
1
、异常概貌:
概念: JAVA 会将所有的异常、错误抽象成为一个类,其根本父类为Throwable。异常是程
序中所有出乎意料的结果,用名称代表发生的问题,见名知义。我们对于程序可能出现的错
误应该做出预案。异常处理可以提高我们系统的容错性、健壮性。
java.lang.Throwable 类是所有异常和错误的顶层类。其两个直接子类是java.lang.Error 和
java.lang.Exception。
Error
对象表示程序错误,是底层的、不可恢复的严重错误。此时程序一定会退出,
已经失去了运行所必须的物理环境。因为程序已经退出了,所以对于Error 错误无法进
行处理。
我们可处理的只是Exception
类的对象表示的程序异常(例外/异常)。
以下区分:
RuntimeException
(未检查异常):RuntimeException 及其子类都称为运行时异常,它
是(UnChecked Exception),特点是Java 编译器不会检查它,可以在编程时避免。也就
是说,当程序中出现此类异常时,即使不用try…catch 捕获,或不用throws 子句抛出,
还是可以编译通过。比如,除数为0 的异常ArrithmeticException,就是运行时异常。
非Runtime
异常(已检查异常):包括除了RuntimeException及其子类外的其它Exception
类及其子类,都属于已检查异常(Checked Exception)。其特点是Java 编译器会检查它,
我们需要用try…catch 语句捕获,或用throws 子句声明抛出,否则编译不会通过。比如
打开文件时找不到文件,就属于已检查异常。
Throwable
Error
错误
严重底层错误
不可避免
不可处理
Exception
异常
RuntimeException
未检查异常
(可处理可不处理)
比如除0 错误、空指针
非Runtime
已检查异常
(必须处理)
比如打开文件时找不到
2
2
、Java
异常处理机制
(1
)try
…
catch
捕获异常(积极处理异常的方式)
try 代码块包含了可能发生异常的程序代码,catch 块紧随其后,用来捕获并处理异常。
格式如下:
try
{
可能出现异常的代码块}
catch
(Exception
e)
{
进行异常处理}
注意:一次异常捕获只会匹配一次try…catch
catch 中要求必须先捕获子类异常再捕获父类异常。
(2
)finally
任何情况下都必须执行的代码段(紧接在try 或catch 代码块后面)。
finally 无论如何都会被执行,除非JVM 退出。所以,finally 代码块常常用于释放被占
用的资源。比如关闭文件、网络、数据库连接等。
(3
)throws
声明可能会抛出的异常(消极处理异常的方式)
格式: 方法名(参数表)throws
后面接要往上抛的异常。
表示该方法对指定的异常不作任何处理,直接抛往上一层。
static void methodA(int i) throws IOException{ //一直向上抛(消极处理)
}
public static void main(String[] args) throws IOException{ //一直抛到JVM
}
多个异常,用逗号隔开。throws IOException, SQLException
throws 后的异常允许多态。比如IOException,会包括抛出其子类。
注意:不允许子类比父类抛出范围更大、更多的异常。
方法覆盖时,修饰符要越来越宽;抛例外则要越来越窄。
throws
和try
…
catch
经常配合使用,把异常传递给最能处理此异常的方法中,体现各
司其职的特点。
Java
中处理异常方式
消极throws 用在方法的声明上
积极try…catch…finally
public static int fn(int b){
try{
return b/2;
}catch(Exception e){
return 0;
}finally{
return b; //返回的结果是一定是b;
}
}
3
(4
)throw
抛出异常
打个比方:
public void eat() throws FoodException{ //自定义FoodException 是以下异常的父类
if(没有食物) throw new NoFoodException(“呵呵,没有食物”);
if(发现苍蝇) throw new FoundFlyException(“哎呀,发现半只苍蝇”);
}
比较throw
和throws
:
throw
是一个语句,它出现在方法体中,用来抛出异常对象。
throws
是出现在方法声明中,表示本方法中会有异常对象向上(调用者)抛出。
throws
后写的是异常类型; throw
后写的是要抛出的异常对象。
(5
)异常处理流程
try…catch…finally,如果遇到return 和System.exit()语句:
一如果在finally 之前遇到System.exit()则finally 语句不再执行,这是finally 不被执行
的唯一情况。因为java.lang.System类的静态方法exit()用于终止当前的Java 虚拟机进程。exit()
的参数表示程序终止时的状态码,0 表示正常终止,非0 表示异常终止。
二return 语句用于退出本方法。如果在try 或者catch 代码块中遇到return 语句时,若
有finally 语句块,会先执行finally 代码块。
三不要在finally 代码块中使用return 语句。因为这样会导致两种潜在错误:A. 覆盖了
try 或catch 块中的return 语句; B. 导致丢失异常。
try{
①
②
③
} catch(XxxException e) {
④
} finally {
⑤
}
⑥
情况一:没有异常,处理顺序为① ② ③ ⑤ ⑥
情况二:在②处有异常,① ② ④ ⑤ ⑥
情况三:有异常,没有被捕获,① ② ⑤ 终止
情况四:如果③后有return 语句,① ② ③ ⑤
情况五:如果遇到System.exit(),则⑤不执行
允许的处理方式:
① try…catch()
② try…finally //与throws 配合使用
③ try…catch…finally
④ try…catch(){} catch(){} … //配多个catch
//注意范围大的异常要写在后面
4
(6
)异常处理规则:
① 只有在异常情况下才使用异常处理机制;
② 保证操作要么一起成功,要么一起失败;
③ try 代码块不要太大;
④ catch 子句中指定具体的异常类型;
⑤ 早抛出,晚捕获。
3
java反射机制详解
反射就是把Java的各种成分映射成相应的Java类。
Class类的构造方法是private,由JVM创建。
反射是java语言的一个特性,它允程序在运行时(注意不是编译的时候)来进行自我检查并且对内部的成员进行操作。例如它允许一个java的类获取他所有的成员变量和方法并且显示出来。Java 的这一能力在实际应用中也许用得不是很多,但是在其它的程序设计语言中根本就不存在这一特性。例如,Pascal、C 或者 C++ 中就没有办法在程序中获得函数定义相关的信息。(来自Sun)
JavaBean 是 reflection 的实际应用之一,它能让一些工具可视化的操作软件组件。这些工具通过 reflection 动态的载入并取得 Java 组件(类) 的属性。
反射是从1.2就有的,后面的三大框架都会用到反射机制,涉及到类"Class",无法直接new CLass(),其对象是内存里的一份字节码.
Class 类的实例表示正在运行的 Java 应用程序中的类和接口。枚举是一种类,注释是一种接口。每个数组属于被映射为 Class 对象的一个类,所有具有相同元素类型和维数的数组都共享该 Class 对象。
基本的 Java类型(boolean、byte、char、short、int、long、float 和 double)和关键字 void 也表示为 Class 对象。Class 没有公共构造方法。
Class 对象是在加载类时由 Java 虚拟机以及通过调用类加载器中的 defineClass 方法自动构造的。
Person p1 = new Person();
//下面的这三种方式都可以得到字节码
CLass c1 = Date.class();
p1.getClass();
//若存在则加载,否则新建,往往使用第三种,类的名字在写源程序时不需要知道,到运行时再传递过来
Class.forName("java.lang.String");
Class.forName()字节码已经加载到java虚拟机中,去得到字节码;java虚拟机中还没有生成字节码 用类加载器进行加载,加载的字节码缓冲到虚拟机中。
另外,大家可以关注微信公众号Java技术栈回复:JVM,获取我整理的系列JVM教程,都是干货。
考虑下面这个简单的例子,让我们看看 reflection 是如何工作的。
import java.lang.reflect.*;
public class DumpMethods {
public static void main(String args[]) {
try {
Class c = Class.forName("java.util.Stack");
Method m[] = c.getDeclaredMethods();
for (int i = 0; i m.length; i++)
System.out.println(m[i].toString());
}
catch (Throwable e){
System.err.println(e);
}
}
}
public synchronized java.lang.Object java.util.Stack.pop()
public java.lang.Object java.util.Stack.push(java.lang.Object)
public boolean java.util.Stack.empty()
public synchronized java.lang.Object java.util.Stack.peek()
public synchronized int java.util.Stack.search(java.lang.Object)
这样就列出了java.util.Stack 类的各方法名以及它们的限制符和返回类型。这个程序使用 Class.forName 载入指定的类,然后调用 getDeclaredMethods 来获取这个类中定义了的方法列表。java.lang.reflect.Methods 是用来描述某个类中单个方法的一个类。
以下示例使用 Class 对象来显示对象的类名:
void printClassName(Object obj) {
System.out.println("The class of " + obj +
" is " + obj.getClass().getName());
}
还可以使用一个类字面值(JLS Section 15.8.2)来获取指定类型(或 void)的 Class 对象。例如:
System.out.println("The name of class Foo is: "+Foo.class.getName());
在没有对象实例的时候,主要有两种办法。
//获得类类型的两种方式
Class cls1 = Role.class;
Class cls2 = Class.forName("yui.Role");
注意第二种方式中,forName中的参数一定是完整的类名(包名+类名),并且这个方法需要捕获异常。现在得到cls1就可以创建一个Role类的实例了,利用Class的newInstance方法相当于调用类的默认的构造器。
Object o = cls1.newInstance();
//创建一个实例
//Object o1 = new Role(); //与上面的方法等价
JAVA中反射是什么
JAVA中反射是动态获取信息以及动态调用对象方法的一种反射机制。
Java反射就是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意方法和属性;并且能改变它的属性。而这也是Java被视为动态语言的一个关键性质。
Java反射的功能是在运行时判断任意一个对象所属的类,在运行时构造任意一个类的对象,在运行时判断任意一个类所具有的成员变量和方法,在运行时调用任意一个对象的方法,生成动态代理。
扩展资料:
JAVA中反射实例:
1、Class superClass=clazz.getSuperclass();//获取父类。
System.out.println("getSuperclass:"+superClass)。
2、Class[] interfaces=clazz.getInterfaces();//获取实现接口。
System.out.println("getInterfaces:"+interfaces.length)。
3、Constructor[] cons=clazz.getConstructors();//构造方法。
System.out.println("getConstructors:"+cons.length)。
参考资料来源:百度百科: JAVA反射机制
关于java反射异常属于什么和java反射的弊端的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。