java 非法提交_Java实现非法访问异常

创建ExceptionTest类,在该类的main()方法中,使用反射获得String类的所有域,不要使用setAccessible方法修改这些域的可见性,然后通过反射获得私有域中与”hash”相匹配的int值,并使用try-catch语句块捕获非法访问异常。

思路分析:

首先使用Class获得一个代表String类的类对象,然后使用Class类的getDeclaredFields()方法获得所有成员变量,并赋值给一个Field型数组,即得到String类的所有域。

使用foreach()循环遍历所有域,使用Field类的getName()方法获得该成员变量的名称,如果域的名字是hash,尝试使用Field类的getInt(Object obj)方法获得指定对象中类型为int的该成员变量的值。

依次捕获IllegalArgumentException异常和IllegalAccessException异常。

代码如下:

import java.lang.reflect.Field;

public class ExceptionTest {

public static void main(String[] args) {

Class> clazz = String.class;//获得代表String类的类对象

Field[] fields = clazz.getDeclaredFields();

for (Field field : fields) {//遍历所有域

System.out.println(field);

if (field.getName().equals("hash")) {//如果域的名字是hash

try {

System.out.println(field.getInt("hash"));// 输出hash的值

} catch (IllegalArgumentException e) {//捕获IllegalArgumentException异常

System.out.println(e);

} catch (IllegalAccessException e) {//捕获IllegalAccessException异常

System.out.println(e);

}

}

}

}

}

效果如图:

031deb8d6f2680fffafcd1e602a0fe01.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值