Java基础概念介绍

一、Java异常

1.1 概念

如果某个方法不能按照正常的途径完成任务,就可以通过另一种路径退出方法。这种情况下会抛出一个封装了错误信息的对象。此时,这个方法会立刻退出同时不返回任何值。另外,调用这个方法的其他代码也会无法继续执行,异常处理机制会将代码交给异常处理器。

1.2 异常分类

Throwable是所有错误和异常的超类。下一层分为Error和Exception。

Error

指的是Java运行时系统内部错误和资源耗尽错误。应用程序不会处理和抛出该类对象。如果出现了这样的错误,除了告知用户,剩下的就是尽力使程序安全的终止。

Exception

Exception又分两种,一种是运行时异常RuntimeException,如NullPointerException,ClassCastException。如果出现运行时异常,一定是程序员的错误;一种是CheckedException,如IOException,SQLException。

1.3异常处理方式

1.3.1 遇到问题不处理,而是继续抛给调用者

抛出异常有三种方式:throw、throws、系统自动抛出
throw和throws区别
位置不同
1、throws用在函数上,后面跟的是异常类,可以跟多个;而throw用在函数内,后面跟的是异常对象。
功能不同
2、throws用来声明异常,让调用者只知道该功能可能出现的问题,可以给出预先的处理方式;throw抛出具体的问题对象,执行到throw,功能已经结束了,跳转到调用者,并将具体的问题对象抛给调用者。
3、throws表示出现异常的一种可能性,并不一定会发生这种异常;throw则是抛出了异常,执行throw则一定抛出了某种异常对象。
4、两者都是消极的处理异常方式,只是抛出或者可能抛出异常,但不会由函数处理异常,真正处理异常的是调用者。

1.3.2 try catch捕获异常

二、Java反射

在运行状态中,对于任意一个类都能知道这个类所有的属性和方法;并且对于任意一个对象,都能够调用它的任意一个方法。这种总动态获取信息以及动态调用对象方法的功能成为Java语言的反射机制。

2.1 反射API

反射API用来生成JVM中的类、接口或对象的信息
1、Class类:反射的核心类,可以获取类的属性,方法等信息
2、Field类:表示类的成员变量,可以用来获取和设置类之中的属性值
3、Method类: 表示类的方法,可以用来获取类中的方法信息或者执行方法
4、Constructor类:表示类的构造方法
反射首先需要获取想要操作的类的Class对象,它是反射的核心。获取Class对象的3种方法:
1、调用某个对象的 getClass()方法
2、调用某个类的 class 属性来获取该类对应的 Class 对象
3、使用 Class 类中的 forName()静态方法(最安全/性能最好)
创建对象的两种方法:
1、 使用 Class 对象的 newInstance()方法来创建该 Class 对象对应类的实例,但是这种方法要求该 Class 对象对应的类有默认的空构造器。
2、调用 Constructor 对象的 newInstance()

三、Java注解

3.1 概念

Annotation是Java提供的一种对元程序中元素关联信息和元数据的途径和方法。Annotation是一个接口,程序可以通过反射来获取指定程序中元素的Annotation对象,然后通过该Annotation对象来获取注解中的元数据信息。

3.2 4中标准元注解

元注解的作用是负责注解其他注解,他们被用来提供对其他Annotation类型说明。

@Target 修饰的对象范围

@Target 说明了 Annotation 所修饰的对象范围: Annotation 可被用于 packages、types(类、接口、枚举、Annotation 类型)、类型成员(方法、构造方法、成员变量、枚举值)、方法参数和本地变量(如循环变量、catch 参数)。在 Annotation 类型的声明中使用了 target 可更加明晰其修饰的目标。

@Retention 定义被保留时间的长短

@Retention 定义了该 Annotation 被保留的时间长短:表示需要在什么级别保存注解信息,用于描述注解的生命周期(即:被描述的注解在什么范围内效),取值(RetentionPoicy)有:
SOURCE:在源文件中有效(即源文件保留)
CLASS:在 class 文件中有效(即 class 保留)
RUNTIME:在运行时有效(即运行时保留)

@Documented 描述-javadoc

@Documented 用于描述其它类型的 annotation 应该被作为被标注的程序成员的公共 API,因此可以被例如 javadoc 此类的工具文档化。

@Inherited 阐述了某个被标注的类型是被继承的

@Inherited 元注解是一个标记注解,@Inherited 阐述了某个被标注的类型是被继承的。如果一个使用了@Inherited 修饰的 annotation 类型被用于一个 class,则这个 annotation 将被用于该class 的子类。

四、Java内部类

Java 类中不仅可以定义变量和方法,还可以定义类,这样定义在类内部的类就被称为内部类。根据定义的方式不同,内部类分为静态内部类,成员内部类,局部内部类,匿名内部类四种。

静态内部类

定义在类内部的静态类,就是静态内部类
1、静态内部类可访问外部类所有的静态变量和方法,即使是private的也一样。
2、静态内部类和一般类一致,可以定义静态变量、方法,构造方法等。
3、其他类使用静态内部类需要使用“外部类.静态内部类”方式
4、Java 集合类 HashMap 内部就有一个静态内部类 Entry。Entry 是 HashMap 存放元素的抽象,HashMap 内部维护 Entry 数组用了存放元素,但是 Entry 对使用者是透明的。像这种和外部类关系密切的,且不依赖外部类实例的,都可以使用静态内部类。

成员内部类

定义在类内部的非静态类,就是成员内部类。成员内部类不能定义静态方法和变量(final修饰的除外)。这是因为成员内部类是非静态的,类初始化的时候先初始化静态成员,如果允许成员内部定义静态变量,那么成员内部类的静态变量初始化顺序是有歧义的。

局部内部类

定义在方法中的类,就是局部类。如果一个类只在某个方法中使用,则可以考虑使用局部类。

匿名内部类

继承一个父类或实现一个接口、直接使用new来生成一个对象的引用。它也是没有 class 关键字,这是因为匿名内部类是直接使用 new 来生成一个对象的引用。

五、Java泛型

泛型提供了编译时类型安全检测机制,该机制允许程序员在编译时检测到非法的类型。泛型的本质是参数化类型,也就是说所操作的数据类型被指定为一个参数。比如我们要写一个排序方法,能够对整型数组、字符串数组甚至其他任何类型的数组进行排序,我们就可以使用 Java 泛型。

5.1 泛型方法

你可以写一个泛型方法,该方法在调用时可以接收不同类型的参数。根据传递的参数类型,编译器适当处理每一个方法调用。

// 泛型方法 printArray
public static < E > void printArray( E[] inputArray ) {
  for ( E element : inputArray ){ 
    System.out.printf( "%s ", element );
  }
}

1、<? extends T>表示该通配符所代表的类型是T类型的子类
2、<? super T>表示该通配符所代表的类型是T类型的父类

5.2 泛型类
5.3 类型通配符?

类型通配符一般是使用?代替具体的类型参数。例如 List<?> 在逻辑上是List,List 等所有 List<具体类型实参>的父类。

5.4 类型擦除

**Java中的泛型基本上都是在编译器这个层次实现的。在生成的Java字节码中是不包含泛型中的类型信息的。**使用泛型的时候加上的类型参数,会被编译器在编译的时候去掉,这个过程就被称为类型擦除。如在代码中定义的 List和 List等类型,在编译之后都会变成 List。JVM 看到的只是 List,而由泛型附加的类型信息对 JVM 来说是不可见的。类型擦除的基本过程也比较单,首先是找到用来替换类型参数的具体类。这个具体类一般是 Object。如果指定了类型参数的上界的话,则使用这个上界。把代码中的类型参数都替换成具体的类。

六、Java序列化(创建可复用的Java对象)

6.1 保存(持久化)对象及其状态到内存或磁盘

Java平台允许我们在内存中创建可复用的Java对象,但一般情况下,只有JVM处于运行时,这些对象才存在,即这些对象的生命周期不会比JVM生命周期更长。但在实际应用中,就可能要求在JVM停止运行之后能够保持(持久化)指定的对象,并在将来重新读取被保存的对象。Java对象序列化功能能帮我们实现该功能。

6.2 序列化对象以字节数组保持-静态成员不保存

使用Java对象序列化,在保存对象时,会把其状态保存为一组字节,在将来,再将这些字节组装成对象。必须注意的是,对象序列化保存的是对象的“状态”,即成员变量。由此可知,对象序列化不会关注类中的静态变量。

6.3 序列化用于远程对象传输

除了在持久化对象时会用到对象序列化之外,当使用 RMI(远程方法调用),或在网络中传递对象时,都会用到对象序列化。Java 序列化 API 为处理对象序列化提供了一个标准机制,该 API 简单易用。

6.4 Serializable 实现序列化

在 Java 中,只要一个类实现了 java.io.Serializable 接口,那么它就可以被序列化。

6.5 ObjectOutputStream 和 ObjectInputStream 对对象进行序列化及反序列化

通过 ObjectOutputStream 和 ObjectInputStream 对对象进行序列化及反序列化。

6.6 writeObject 和 readObject 自定义序列化策略

在类中增加 writeObject 和 readObject 方法可以实现自定义序列化策略。

6.7 序列化 ID

虚拟机是否允许反序列化,不仅取决于类路径和功能代码是否一致,一个非常重要的一点是两个类的序列化 ID 是否一致(就是 private static final long serialVersionUID)

6.8 序列化子父类说明

要想将父类对象也序列化,就需要让父类也实现 Serializable 接口。

6.9 Transient 关键字阻止该变量被序列化到文件中

1、在变量声明前加上Transient 关键字,可以阻止该变量被序列化到文件中,在被反序列化后,transient 变量的值被设为初始值,如 int 型的是 0,对象型的是 null。
2、服务器端给客户端发送序列化对象数据,对象中有一些数据是敏感的,比如密码字符串等,希望对该密码字段在序列化时,进行加密,而客户端如果拥有解密的密钥,只有在客户端进行反序列化时,才可以对密码进行读取,这样可以一定程度保证序列化对象的数据安全。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值