一、抽象类为什么不能被实例化?
抽象类确实有构造方法,但这个构造方法是用来被子类调用的,因为任何子类都必须调用从Object开始的所有父亲的构造方法,才算完成初始化工作。如果抽象类被实例化,就会报错,编译无法通过。而接口里不含构造器。自然无法被实例化。
二、in和out
out是从程序里出去的数据,in是进入到程序的数据。
三、编译时异常、运行时异常
编译时异常需要我们手动的进行捕捉处理,也就是用try-catch进行捕捉处理。运行时异常只有编译器在编译运行时才会出现,这些不需要我们手动处理。
四、接口方法用void定义,其实现类应该是public void
接口方法默认是public abstract 的
五、重载和重写/覆盖
重载的要求:方法名称必须相同,参数列表必须不同(个数不同、类型不同、参数类型排列顺序不同)
同名不同参
重写/覆盖:同名同参同返回类型
六、Math.floor() 、Math.ceil() 、Math.round()
math.floor():向下取整,返回double类型
math.ceil():向上取整,返回double类型
math.round():四舍五入,若入参为float类型,返回int;若入参为double类型,则返回long
七、Java数据库连接库JDBC使用的设计模式——>桥接模式:将抽象部分与它的实现部分分离,使他们可以独立的变化。
八、Java JVM参数配置
- Xms:起始内存,初始堆大小
- Xmx:最大内存,最大堆大小
- Xmn:新生代内存,年轻代大小,包含1个eden和2个survivor
- XX:NewRatio=n:设置年轻代和年老代的比值,表示年轻代:年老代=1:n
- XX:SurvivorRatio=n:设置年轻代里eden和2个survivor的比值,表示eden:survivor=n:2
- XX:MaxPermSize=n:设置持久代大小
九、枚举类有几个实例就会调用几次构造方法
十、servlet处于服务器进程中,它通过多线程方式运行其service方法,一个实例可以服务于多个请求,并且其实例一般不会销毁,而CGI对每个请求都产生新的进程,服务完成后就销毁,所以效率上低于servlet
十一、volatile
一旦一个共享变量(类的成员变量、类的静态成员变量)被volatile修饰之后,那么就具备了两层含义:
- 保证了不同线程对这个变量进行操作时的可见性,即一个线程修改了某个变量的值,这个新值对其他线程来说时立即可见的
- 禁止进行指令重排序。
volatile只提供了保证访问该变量时,每次都是从内存中读取最新值,并不会使用寄存器缓存该值——每次都是从内存中读取。而对该变量的修改,volatile并不提供原子性的保证。由于及时更新,很可能导致另一线程访问最新变量值,无法跳出循环的情况,多线程下计数器必须使用锁保护。
十二、内部类
静态内部类,不能访问外部的非静态资源
成员内部类,可以访问外部的所有资源,但本身不可有静态属性,因为自己本身就需要依靠外部类的实例化
局部内部类:不可被访问修饰符和static修饰,只能访问final变量和形参。一般在外部类的方法中。
匿名内部类:没有构造器、没有静态资源、无法被访问修饰符和static修饰,只能创建一个匿名内部类的实例,创建的时候一定在new的后面。