1.public,protected,private的区别,继承方法以及访问权限
作用域 | 当前类 | 同一个package | 子孙类 | 其他包 |
public | ✔ | ✔ | ✔ | ✔ |
protected | ✔ | ✔ | ✔ | ❌ |
default | ✔ | ✔ | ❌ | ❌ |
private | ✔ | ❌ | ❌ | ❌ |
tips:不写权限修饰符就是默认的default
2.float f = 3.4; 书写是否正确?
不正确。
3.4是双精度数,将双精度型(double)赋值给单精度型(float)属于向下转型,会造成精度的损失,因此需要强制类型转换才可以
float f = (float)3.4或者float f=3.4F;
3.short s1 = 1;s1 = s1+1;这个写法有错误吗?short s2 = 1;s2+=1;那么这种写法是否正确呢?
第一种写法是不对的,因为1是int类型,因此在计算s1+1的时候其运算的结果也是int类型的,不可能将一个int类型的数据赋值给一个short类型的变量,如果必须使用这种写法,需要将运算结果进行强制类型转换。
第二种写法是可行的,s2+=1;“+=”操作符会进行隐式自动类型转换,是Java语言规定的运算符,可以进行正常的编译,其效果相当于
s2 = (short)(s2+1);
4.Java中final、finally、 finalize的区别和用法
①final
final是一个关键字也是一个修饰符。
被final修饰的类是无法被继承
对于一个final修饰的变量,如果是基本数据类型的变量,则其数值一旦在初始化后就不能进行更改。如果其修饰的是一个引用类型的变量,则在对其进行初始化后则无法再让其指向对的对象。但是它指向的对象的内容是可变的。
被final修饰的方法是无法被重写的,但是允许重载。
②finally
finally是个关键字
一般在处理异常的时候finally结构块来执行任何清除操作,不管是否有异常抛出或者捕获,finally结构块都会被 ,通常用于释放资源。
finally正常情况下一定会被执行,但是有两个极端情况除外:
如果对应的try结构体没有被执行到,那么该try对应的finally块也不会被执行。
如果在try块执行的过程中jvm关机了,例如执行了system.exit(n);则finally块也不会被执行的。
finally块中如果有return语句,则会覆盖try或者catch中的return语句,导致二者无法return,所以不要在finally块中出现return语句。
③finalize
finalize()方法是Object类中的protected方法,子类可以覆盖该方法进行资源的清理工作。GC在回收对象的时候会调用该方法。
5.深拷贝和浅拷贝的区别是什么?
①浅拷贝
仅仅复制所考虑的对象,而不复制其所引用的对象。
②深拷贝
深拷贝把要复制的对象所引用的对象都复制了一遍。
6.Java中操作字符串的类有哪些?有什么区别?
String StringBuffer StringBuilder
String与其他两个的区别在于,String是不可变的对象。每次操作到会生成新的对象,然后将指针指向新的String对象。而另外两个可以在原有对象的基础上进行操作。如果需要经常改动的字符串不要使用String。
StringBuffer与StringBuilder的区别是StringBuffer是线程安全的,StringBuilder是非线程安全的,线程安全会造成性能上的下降,进而StringBuilder的性能要 StringBuffer,在单线程下使用StringBuilder,多线程下使用StringBuffer。
7.String str1 = "abc" 和 String str1 = new String("abc")两种写法一样吗?
不一样
String str1 = "abc" 发生在常量池;
String str1 = new String("abc") 发生在堆内存;
8.抽象类可以用final修饰吗?
不可以的。
定义抽象类是让其他类进行继承,而被final修饰的类是不可以被继承的。
9.重载和重写的区别
重载是指的方法名称相同,参数类型以及个数不同。是行为水平方向的不同实现。对于编译器来说, 方法名称和参数列表组成了一个唯一的键,我们称之为方法签名。
重写是指子类实现接口或继承父类时,保持方法签名完全一致,实现不同的方法体。是行为垂直方向的实现,重写方法访问权限不能变小,返回值类型和抛出异常的类型不能变大。
10.jdk1.8的新特性
Ⅰ.lambda表达式:允许把函数作为参数传递到方法中,简化匿名内部类代码。
Ⅱ.函数式接口:使用 @FunctionalInterface 标识,有且仅有一个抽象方法,可被隐式转换为 lambda 表达式。
Ⅲ.方法引用:可以引用已有类或对象的方法和构造方法,进一步简化 lambda 表达式。
Ⅳ.接口可以定义 default 修饰的默认方法,降低了接口升级的复杂性,还可以定义静态方法。
Ⅴ.Stream 类:引入函数式编程风格,提供了很多功能,使代码更加简洁。方法包括 forEach 遍历、 count 统计个数、 filter 按条件过滤、 limit 取前 n 个元素、 skip 跳过前 n 个元素、 map 映射 加工、 concat 合并 stream 流等。
Ⅵ.日期:增强了日期和时间 API,新的 java.time 包主要包含了处理日期、时间、日期/时间、时区、时刻 和时钟等操作。
Ⅶ.Optional 类:处理空指针异常,提高代码可读性。
Ⅷ.JavaScript:提供了一个新的 JavaScript 引擎,允许在 JVM上运行特定 JavaScript 应用。