Java基础知识点总结笔记

面向对象的三大特性

继承:通常只能单继承,内部类实现多继承,接口能够多继承
java

封装:访问权限控制public>protected>包>private内部类也是一种封装程序员

多态:编译时多态,体如今向上转型和向下转型,经过引用类型判断调用哪一个方法(静态分配)。运行时多态,体如今同名函数经过不一样的参数实现多种方法(动态分配)。数组

基本数据类型

1.基本类型位数,自动装箱,常量池。
多线程

2.例如byte类型是1byte也就是8位,能够表示的数字是-128到127,由于还有个0,加起来一共是256,也就是2的八次方。32位和64位机器的int是4个字节也就是32位,char是一个字节就是8位,float是4个字节,double是8个字节,long是8个字节。框架

3.基本数据类型的包装类只在数字范围-128到127中用到常量的池,会自动拆箱装箱,其他数字范围的包装类则会新建实例。jvm

String及包装类

1.String类型是final类型,在堆中分配空间后内存地址不可变。函数

2.底层是final修饰的char[]数组,数组的内存地址一样不可变。但实际上能够经过修改char[n] = 'a'来进行修改,不会改变String实例的内存值,不过在jdk中,用户没法直接获取char[],也没有方法能操做数组。因此String类型的不可变实际上也是理论上的不可变。因此咱们在分配String对象之后,若是将其 = "abc",那也只是改变了引用的指向,实际上没有改变原来的对象。ui

3.StringBuffer和StringBuilder底层是可变的char[]数组,继承父类AbstracStringBuilder的各类成员和方法,实际上的操做都是由父类方法来完成的。spa

final关键字

1.final修饰基本数据类型保证不可变线程

2.final修饰引用保证引用不能指向别的对象,不然会报错。

3.final修饰类,类的实例分配空间后地址不可变,子类不能重写全部父类方法。所以在cglib动态代理中,不能为一个类的final修饰的函数作代理,由于cglib要将被代理的类设置为父类,而后再生成字节码。final修饰方法,子类不能重写改方法。

抽象类和接口

1.抽象类能够有方法实现。抽象类能够有非final成员变量。抽象方法要用abstract修饰。抽象类能够有构造方法,可是只能有子类进行实例化。

2.接口能够用extends加多个接口实现多继承。接口只能有public final类型的成员变量。接口只能有抽象方法,不能有方法体,接口不能实例化,可是能够做为引用类型。

代码块和加载顺序

假设该类是第一次进行实例化。那么有以下加载顺序

静态老是比非静态优先,从早到晚的顺序是:

1.静态代码块和静态成员变量的顺序根据代码位置先后来决定。

2.代码块和成员变量的顺序也是根据代码位置来决定

3.最后才调用构造方法。

包,内部类,外部类

1.Java项目通常从src目录开始有com...A.java这样的目录结构。这就是包结构。因此通常编译后的结构是根包结构如出一辙的,这样的结构保证了import时能找到正确的class引用包访问权限就是指同包下的类可见。

import通常加上全路径,而且使用.*时只包含当前目录的全部类文件,不包括子目录。

2.外部类只有public和default两种修饰,要么全局可访问,要么包内可访问。

3.内部类能够有所有访问权限,由于它的概念就是一个成员变量,因此访问权限设置与通常的成员变量相同。

非静态内部类是外部类的一个成员变量,只跟外部类的实例有关。

静态内部类是独立于外部类存在的一个类,与外部类实例无关,能够经过外部类.内部类直接获取Class类型。

异常

1.异常体系的最上层是Throwable类。子类有Error和Exception。Exception的子类又有RuntimeException和其余具体的可检查异常。

2.Error是jvm彻底没法处理的系统错误,只能终止运行。运行时异常指的是编译正确但运行错误的异常,如数组越界异常,通常是人为失误致使的,这种异常不用try catch,而是须要程序员本身检查。可检查异常通常是jvm处理不了的一些异常,但又常常会发生,好比Ioexception,Sqlexception等,是外部实现带来的异常。

3.多线程的异常流程是独立的,互不影响。大型模块的子模块异常通常须要从新封装成外部异常再次抛出,不然只能看到最外层异常信息,难进行调试。日志框架是异常报告的最好帮手,log4j,slf4j中,在工做中必不可少。

泛型

1. Java中的泛型是伪泛型,只在编译期生效,运行期自动进行泛型擦除,将泛型替换为实际上传入的类型。

泛型类用classA {

}

2. 这样的形式表示,里面的方法和成员变量均可以用T来表示类型。泛型接口也是相似的,不过泛型类实现泛型接口时能够选择注入实际类型或者是继续使用泛型。

3. 泛型方法能够自带泛型好比void <E> go();

泛型可使用?通配符进行泛化 Object能够接受任何类型

也可使用 这种方式进行上下边界的限制。

Class类和Object类

1. Java反射的基础是Class类,该类封装全部其余类的类型信息,而且在每一个类加载后在堆区生成每一个类的一个Class<类名>实例,用于该类的实例化。

2. Java中能够经过多种方式获取Class类型,好比A.class,new A().getClass()方法以及Class.forName("com.?.?.A")方法。

3. Object是全部类的父类,有着本身的一些私有方法,以及被全部类继承的9大方法。

知乎上有人讨论Object和Class类型谁先加载谁后加载,由于每一个类都要继承Object,可是又得先被加载到堆区,事实上,这个问题在JVM初始化时就解决了,不必多想

 

 未完待续。。。

相关文章
相关标签/搜索