java面试| 精选基础题(3)

时间:2022-03-18 14:27:48

每天进步一点点,距离大腿又近一步!

阅读本文大概需要6分钟

系列文章

java面试| 精选基础题(1)

java面试|精选基础题(2)

1.float f=3.4;是否正确?

答:不正确,编译无法通过。3.4是双精度数,将双精度型(double)赋值给浮点型(float)属于下转型(down-casting,也称为窄化)会造成精度损失,因此需要强制类型转换float f =(float)3.4; 或者写成float f =3.4F;。(推荐阅读:java”小心机”(1)【资源彩蛋!】第4点类型转换)

2.+=的隐式转换

例1:short s1 = 1; s1 = s1 + 1;有错吗?例2:short s1 = 1; s1 += 1;有错吗?
  • 对于例1,编译不通过。由于1是int类型,因此s1+1运算结果也是int 型,需要强制转换类型才能赋值给short型。(相关阅读:java”小心机”(1)【资源彩蛋!】第5点类型提升)

  • 对于例2,可以正确编译.因为s1 += 1;相当于s1 = (short)(s1 + 1);编译器会自动隐式直接将+=运算符后面的操作数强制装换为前面变量的类型。

3.try{}里有一个return语句,代码执行顺序如何?

public class ReturnInTry {    public static void main(String[] args){       System.out.println(test());    }   static public String test(){       String str = "return1";        try{            return str;        }finally {            str = "return2";            System.out.println("finally");        }    }}

输出:

finallyreturn1

由此可见,finally代码块中的代码会在return语句前执行,但为什么finally代码块中的str = "return2";未生效呢?

其实它这样执行的:当try中含有return语句且存在finally代码块,return语句不会立刻返回而是记录下该返回值(存在某个地方),待finally代码块执行完毕后再返回该值,所以在finally代码块中无法改变return的返回值。

4.for与foreach的区别

  • for 效率更高,可以在遍历的过程中对源数组或者集合进行修改

  • foreach 便捷简单;更安全

    foreach实际上使用迭代器实现遍历的,其中会产生中间变量,导致性能的降低;foreach虽然能遍历数组或者集合,但是只能用来遍历,无法在遍历的过程中对数组或者集合进行修改

5.java的this关键字

  • 概念

    this是自身的一个对象,代表对象本身,可以理解为:指向对象本身的一个指针。

  • 用法

    1.普通的直接引用

public class ThisTest {    public ThisTest retutrnThis(){        //this相当于是指向当前对象本身        //返回对象本身        return this;    }}

2.形参与成员名字重名时,用this来区分

public class ThisTest {    private String name;    public void ThisTest (String test){        this.test = test;    }}

3.引用构造函数

public class ThisTest {    private String name;    private int count;    public void ThisTest (String test){        this.test = test;    }    public void ThisTest (String test,int count){         //调用另一个构造函数        //只能在第一行调用,且只能调用一次        this.ThisTest(test);        this.count = count;    }}

6.java的super关键字

  • 概念

    this和super很像,this指向的是当前对象本身,super指向的是当前调用对象的父类。子类创建对象时调用构造函数,会隐式调用父类的无参构造方法,创建一个子类对象的同时,该子类对象还包含了一个父类对象。该父类对象在子类对象内部(super指向该对象)。

  • 作用

    1.主要存在于子类方法中,用于指向子类对象中父类对象。

    2.访问父类的属性

    3.访问父类的函数

    4.访问父类的构造函数

  • 必须使用super的时刻

    1.父类覆盖了无参构造函数时

public class Father { public String name; public Father(String name) {  this.name = name; }}public class Son extends Father{ public Son(String name) {  //必须调用,否则他会默认调用父类的无参构造函数,  //而父类的无参构造函数已经被有参的覆盖,所以找不到  super(name); }}

2.子类重写了父类的方法,又想用父类该方法时

class Parents{    Public Parents(){}    public void write(){        System.out.println("Parents");   }}class Children extends Parents{    Public Children(){}    public void write(){        System.out.println("Children");        super.write();//调用父类的write方法   }}

热门阅读:

**实用代码|javaMail发送邮件(文末重磅资源!)

【推荐两款神器】不限速下载、追剧神器

java”小心机”(1)【资源彩蛋!】**

end~thanks!

java面试| 精选基础题(3)

一个立志成大腿而每天努力奋斗的年轻人

期待你的到来!

java面试| 精选基础题(3)

如果觉得文章不错,请点个赞、分享给你的朋友呗!