JAVA学习笔记—review基本知识[反射与异常]

1、异常:

1.1异常的分类:

Java会将所有的异常封装成对象,其根本父类为Throwable。

Throwable有两个子类:Error 和Exception。

1.1.1 Error:一个Error对象表示一个程序错误,指的是底层的低级的不可恢复的严重错误

遇到Error,程序一定会退出,因为已经失去了运行所必须的物理环境。

对于Error我们无法进行处理,因为我们是通过程序来应对错误的,可是程序已经退出了。

1.1.2 Exception:由特定因素,导致程序无法继续,但不影响虚拟机的正常执行。

未检查异常(Runtime Exception):

是因为程序员没有进行必要的检查,由于程序员的疏忽而引起的异常。

是不可避免的,对于已检查异常必须处理,否则编译不通过。

已检查异常(非Runtime Exception):

对于未检查异常可以不处理,编译可以通过,应对未检查异常的方法就是养成良好的检查习惯

1.2  异常处理的机制:

当一个方法中有一条语句出现了异常,它就会throw(抛出)一个异常对象(throw 异常对象),然后后面的语句不会执行,而返回上一级方法,其上一级方法接受到了异常对象之后,有可能对这个异常进行处理(进行处理则不会上抛),也可能将这个异常传到它的上一级,如果最上一级(main方法)不处理就会传给虚拟机,虚拟机就会终止程序的运行。

1.2.1 异常的处理方式:throws和try-catch方法

try-catch处理方式:
try{ //一个

(1)可能出现异常的语句

} catch(XxxException e /*捕获的异常*/){//0或n个

(2)处理异常的代码

} finally{  //0或1个

(3)必须要执行的代码

}
(4)方法中的其他代码

如果代码正确,那么程序不经过catch语句直接向下运行;

如果代码不正确,则将返回的异常对象和e进行匹配,如果匹配成功,则处理其后面的异常处理代码。

try中如果发现错误,即跳出try块去匹配catch,那么try后面的语句就不会被执行。

一个try可以跟多个catch语句,用于处理不同情况,但是不能将父类型的exception的位置写在子类型的excepiton之前。

在try-catch后还可以再跟一子句finally。其中的代码语句论有没有异常都会被执行(因为finally子句的这个特性,所以一般将释放资源,关闭连接的语句写在里面)。

finally中的代码和try-catch中的代码冲突时,finally中的代码一定会被执行且会忽略try-catch中的代码。但是如果try-catch中有System.exit(0);(虚拟机退出语句),则不会去执行

fianlly中的代码。

1.2.2 throws/throw处理方式:

throw 写在方法内,后面跟一个异常对象。

throws 在方法的定义中说明方法可能抛出的异常,后面跟异常类的名字,声明这个方法将不处理异常,把异常交给上一级方法处理。

调用时,调用者不能抛出范围更小的异常.

对于方法a,如果它定义了throws Exception。那么当它调用的方法b返回异常对象时,方法a并不处理,而将这个异常对象向上一级返回,如果所有的方法均不进行处理,返回

到主方法,如主方法也不进行处理,则到虚拟机中,程序中止。

如果在方法的程序中有一行throw new Exception(),那么其后的程序不执行,如果没有对这个可能出现的检查结果进行处理,那么程序就会报错。

throws和throw没有必然的联系。

注意:
方法的覆盖中,如果子类的方法抛出的例外是父类方法抛出的例外的父类型,那么编译就会出错:子类无法覆盖父类。
子类抛出的例外或者与父类抛出的例外一致,或者是父类抛出例外的子类型,或者子类型不抛出例外。
如果父类型无throws时,子类型也不允许出现throws。此时只能使用try catch。
1.2.3 自定义异常:

a. 使其继承Exception或者RuntimeException

b. 写构造器,直接调用父类的构造器

断言(assert):用来调试、测试代码
格式:
assert 布尔表达式: 字符串  (如果布尔表达式为false时,这个字符串才会显示)

注意:
assert默认是关闭的,使用时需要使用" -ea "进行开启," -da "是关闭,如:java -ea 类名。
断言是以异常方式去执行的,当断言的布尔表达式为假时,会中断代码。
不能继承性的打开(java -ea:类名  这样只能打开该类,如果存在父类,不会去打开父类)

2、反射

反射:在运行时动态分析或使用一个类进行工作。

2.1 java.lang.Class类:描述类信息的类。

类对象:描述一个类信息的对象,当虚拟机加载类的时候,就会创建这个类的类对象并加载该对象,Class是类对象的类型。

获得类对象的方式:

用" 类名.class "获得这个类的类对象。

用类的对象掉用getClass(),如object.getClass()得到这个对象的类型的类对象。

可以使用Class.forName(类名),也可以得到这个类的类对象,(注意,这里写的类名必须是全限定名(全名),是包名加类名,XXX.XXX.XXXX)。

基本类型也有类对象,用" 封装类.TYPE "可以获得对应的基本类型的类对象。

2.2 java.lang.reflect包下的三个重要类:

Field属性类:用来描述属性的信息。
Method方法类:方法的信息的描述。
Constructor构造方法类:用来描述构造方法的信息。

2.3  Class类中的常用方法:

newInstance() 
创建此 Class 对象所表示的类的一个新实例(调用无参构造创建的对象)。
getDeclaredMethods()
获得的是一个Method方法类对象的数组,获得本类(不包括父类)声明的所有(包括private的)方法对象。
getMethods()     //推荐使用
获得的是一个Method方法类对象的数组,获得所有(父类的也包括)publice的方法对象。
getDeclaredConstructors()
获得的是一个Constructor构造方法类对象的数组,获得这个类声明的所有构造方法对象。
getConstructors()    //推荐使用
获得的是一个Constructor构造方法类对象的数组,获得所有publice的构造方法对象。
getDeclaredFields()    //推荐使用
获得的是一个Field属性类对象的数组,获得本类声明的所有属性的属性对象。
getFields()
获得的是一个Field属性类对象的数组,获得所有publice的属性对象。

使用反射构造一个类的对象的步骤:
a. 获得类对象
b. 获得构造方法对象
c. 获得对象,用构造方法对象调用构造方法,如果使用无参构造方法,可以跳过第二步,直接使用" 类对象.newInstance() "方法来获得这个类的对象
d. 获得方法对象
e. 用方法对象调用方法(用这个类的对象作为第一参数)

2.4 如下面的例子:

反射机制的实现类:

  1. import java.lang.reflect.Field;
  2. import java.lang.reflect.Method;
  3. import java.util.HashMap;
  4. import java.util.Map;
  5. import java.util.Set;public class TestReflect {public static Object get(String className , Map<String,Object> map) throws Exception{
  6. Class c = Class.forName(className);                  //获得类对象
  7. Object o = c.newInstance();                   //获得对象
  8. Set<String> set = map.keySet();
  9. for(String str : set){
  10. String s = "set" + str.substring(0,1).toUpperCase()+str.substring(1);
  11. Field f = c.getDeclaredField(str);
  12. Method m = c.getMethod(s, f.getType());        //获得方法对象
  13. m.invoke(o, map.get(str));                       //用方法对象调用方法
  14. }
  15. return o;
  16. }
  17. public static void main(String[] args) throws Exception {Map m = new HashMap();
  18. m.put("name", "zhang");
  19. m.put("age", 22);
  20. Object o = get("day07.reflect.Student",m);
  21. Student s = (Student) o;
  22. System.out.println(s.getName() + "   " + s.getAge());
  23. Map m1 = new HashMap();
  24. m1.put("name", "li");
  25. m1.put("gender", "男");
  26. Object o1 = get("day07.reflect.Teacher",m1);
  27. Teacher t = (Teacher) o1;
  28. System.out.println(t.getName() + "    " + t.getGender());
  29. }
  30. }
  31. 学生类:
  32. package day07.reflect;public class Student {
  33. private String name;private int age;public int getAge() {
  34. return age;
  35. }public void setAge(int age) {
  36. this.age = age;
  37. }public String getName() {
  38. return name;
  39. }public void setName(String name) {
  40. this.name = name;
  41. }
  42. }教师类:
  43. package day07.reflect;public class Teacher {
  44. private String name;private String gender;public String getGender() {
  45. return gender;
  46. }public void setGender(String gender) {
  47. this.gender = gender;
  48. }public String getName() {
  49. return name;
  50. }public void setName(String name) {
  51. this.name = name;
  52. }}

最后送自己一句话:先相信你自己,然后别人才会相信你。 ——(俄国) 屠格涅夫

JAVA学习笔记—review基本知识[反射与异常]的更多相关文章

  1. Java学习笔记day07_琐碎知识_水仙花数_ASCII码_冒泡排序_简单选择排序_折半查找

    琐碎知识: 水仙花数, ASCII码, 冒泡排序, 简单选择排序, 折半查找 1.水仙花数 每位数的平方的和等于本身. 如100到999之间的水仙花数满足: 个位的平方+十位的平方+百位的平方 = 本 ...

  2. java学习笔记1--基础知识

    1.java数据类型 2.类之间的几种关系

  3. java学习笔记之基础知识

    1.class不加修饰符默认default,只在当前包里能用. 2.构造函数前面的修饰符的作用类似class的,限制引用的权限. 3.java对象的创建其实就是类的实例化,类的实例化就是在堆上copy ...

  4. 20145330《Java学习笔记》第一章课后练习8知识总结以及IDEA初次尝试

    20145330<Java学习笔记>第一章课后练习8知识总结以及IDEA初次尝试 题目: 如果C:\workspace\Hello\src中有Main.java如下: package cc ...

  5. 20145230《java学习笔记》第九周学习总结

    20145230 <Java程序设计>第9周学习总结 教材学习内容 JDBC JDBC简介 JDBC是用于执行SQL的解决方案,开发人员使用JDBC的标准接口,数据库厂商则对接口进行操作, ...

  6. 0035 Java学习笔记-注解

    什么是注解 注解可以看作类的第6大要素(成员变量.构造器.方法.代码块.内部类) 注解有点像修饰符,可以修饰一些程序要素:类.接口.变量.方法.局部变量等等 注解要和对应的配套工具(APT:Annot ...

  7. 0032 Java学习笔记-类加载机制-初步

    JVM虚拟机 Java虚拟机有自己完善的硬件架构(处理器.堆栈.寄存器等)和指令系统 Java虚拟机是一种能运行Java bytecode的虚拟机 JVM并非专属于Java语言,只要生成的编译文件能匹 ...

  8. 《Java学习笔记(第8版)》学习指导

    <Java学习笔记(第8版)>学习指导 目录 图书简况 学习指导 第一章 Java平台概论 第二章 从JDK到IDE 第三章 基础语法 第四章 认识对象 第五章 对象封装 第六章 继承与多 ...

  9. 20145330第十周《Java学习笔记》

    20145330第十周<Java学习笔记> 网络编程 网络编程就是在两个或两个以上的设备(例如计算机)之间传输数据.程序员所作的事情就是把数据发送到指定的位置,或者接收到指定的数据,这个就 ...

随机推荐

  1. 强烈推荐优秀的Vue UI组件库

    Vue 是一个轻巧.高性能.可组件化的MVVM库,API简洁明了,上手快.从Vue推出以来,得到众多Web开发者的认可.在公司的Web前端项目开发中,多个项目采用基于Vue的UI组件框架开发,并投入正 ...

  2. VMware安装Centos7虚拟机

    首先安装虚拟机很简单,所以呢,具体的安装过程就引用别人的博客,这篇文字很详细,引用之后会在后面加上一些遇到的问题: 原文:https://blog.csdn.net/babyxue/article/d ...

  3. forward(转发)和redirect(重定向)的区别

    在学习Servlet和JSP时,经常会使用到forward和redirect,我们先来看这两者在Servlet中的调用方式: 1.forward request.getRequestDispatche ...

  4. 性能测试学习第一天-----概念、环境、LR录制&参数化

    1.性能测试的概念: 通过一定的手段,在多并发情况下,获取被测系统的各项性能指标, 验证被测系统在高并发下的处理能力.响应能力.稳定性等,能否满足预期.定位性能瓶颈,排查性能隐患,保障系统的质量,提升 ...

  5. (四)Lock,ReentrantLock,ReentrantReadWriteLock类的使用以及相关api---synchronized进阶

    这篇博客记录了Lock,ReentrantLock,ReentrantReadWriteLock类的使用以及其一些api: 码字不易~~另外<java多线程编程核心技术>这本书读着很爽 前 ...

  6. Java 并发:学习Thread 类

    Java 中 Thread类 的各种操作与线程的生命周期密不可分,了解线程的生命周期有助于对Thread类中的各方法的理解.一般来说,线程从最初的创建到最终的消亡,要经历创建.就绪.运行.阻塞 和 消 ...

  7. 移动端 rem单位做适配的 媒体查询节点

    @media screen and (min-width:300px){html,body,input{font-size:15px}}@media screen and (min-width:320 ...

  8. Java 安全之:csrf防护实战分析

    上文总结了csrf攻击以及一些常用的防护方式,csrf全称Cross-site request forgery(跨站请求伪造),是一类利用信任用户已经获取的注册凭证,绕过后台用户验证,向被攻击网站发送 ...

  9. ROS中local costmap的原点坐标系

    local costmap是一个依赖于其他坐标系存在的坐标系统,它并不维护自己的坐标系,而是在另一个坐标系中设定坐标原点,然后记下自己的宽与高.它使用数据结构nav_msgs/OccupancyGri ...

  10. Java8 日期 API 业务使用

    最近在做账单结算业务,需要根据客户选择的结算方式来推算下一次结算日期以及该次结算日期段. 推算日期这样的业务直男君以前就写过,只不过使用的是熟悉的 java.util.date 和 java.util ...