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中用到常量的池,会自动拆箱装箱,其余数字范围的包装类则会新建实例。
String及包装类
1.String类型是final类型,在堆中分配空间后内存地址不可变。
2.底层是final修饰的char[]数组,数组的内存地址同样不可变。但实际上可以通过修改char[n] = 'a'来进行修改,不会改变String实例的内存值,不过在jdk中,用户无法直接获取char[],也没有方法能操作数组。所以String类型的不可变实际上也是理论上的不可变。所以我们在分配String对象以后,如果将其 = "abc",那也只是改变了引用的指向,实际上没有改变原来的对象。
3.StringBuffer和StringBuilder底层是可变的char[]数组,继承父类AbstracStringBuilder的各种成员和方法,实际上的操作都是由父类方法来完成的。
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初始化时就解决了,没必要多想
未完待续。。。
最新文章
- php面向对象编程(一)
- 几何服务,cut功能测试
- js设置本周 本月 本年
- 关于QT写注册表开机自启动
- chrome 49 版本 跨越 --args --disable-web-security --user-data-dir
- Moq的使用
- POJ 1300 Door Man(欧拉回路的判定)
- OpenGL第12-14讲小结
- 微软发布WP SDK8.0 新增语音、应用内支付等原生API
- socket网络编程快速上手(二)——细节问题(4)
- Android使用Apache的httpmime包post提交数据
- 设计模式 - 代理模式(jdk)
- java8之lambda表达式(1)-基本语法
- 201521123115《java程序设计》第9周学习总结
- Docker 共有 13 个管理命令和 41 个通用命令,以下是常用 Docker 命令列表
- windows快速搭建FTP工具Serv-U FTP Server
- 2; HTML 基本结构
- 2018/09/17《涂抹MySQL》【性能优化及诊断】学习笔记(七)
- POJ3904 Sky Code
- Linux+Redis实战教程_day01_Linux系统上安装tomcat