博客
关于我
java基础面试题(四)
阅读量:252 次
发布时间:2019-02-28

本文共 2221 字,大约阅读时间需要 7 分钟。

  1. String类是否可以被继承?

    答:不行,因为String类被final修饰符修饰,属于不可变类。

  2. {String s = “Hello”;s = s + " world!";}这两段代码执行后,原始的 String 对象中的内容有没变?

    答:没有,因为String类是不可变类,所以String类型的对象都是不可变对象,所以以上两段代码其实产生了两个String对象,一个是原来的"Hello",还有一个是"Hello world!"。原来的"Hello"对象依旧存在,只是变量s的引用不再指向它,而是指向新的对象"Hello world!"的内存地址。

  3. String s = new String(“x”);创建了几个 String 对象?

    答:一个或者两个。因为"x"属于常量,因此被创建后会放置在常量池中,以后只要有引用"x",都会从常量池中获取。而new关键字每次使用都会创建新的String对象。所以如果常量池原来就有"x"常量,那么这段代码就只会通过new关键字创建一个对象,所以是一个。反之如果常量池原来没有"x"常量,那么会先创建"x"对象,再new出新的String对象,所以是2个。

  4. 抽象类可以用final修饰符修饰么?

    答:不行,首先我们使用抽象类就是为了让其他类继承使用,而final修饰的类被称为最终类,无法被继承。而且用final修饰抽象类,在编译阶段就会报错,结果如下:
    在这里插入图片描述
    5.static修饰的方法内部可以调用非static修饰的方法么?
    答:不行。首先要知道static的方法是类方法,类加载完就完成了初始化,而非static修饰的方法是成员方法,只有创建出对象实例后,通过这个对象实例才能够调用该方法。试想下,如果我们直接调用一个static修饰的方法,但是这时对象还没完成实例化,那么这时候内部的非static修饰的方法就无法确定到底是关联哪个对象,自然也就无法成功调用。当然你要是在static修饰的方法中就创建出对象实例,然后再通过这个对象实例调用非static修饰的方法,自然是可以的,实例代码如下:

public class TestMain {       public static void getStatic() {           System.out.println("静态方法调用");        TestMain testMain = new TestMain();        testMain.get();    }    public void get() {           System.out.println("普通方法调用");    }    public static void main(String[] args) throws Exception {           TestMain.getStatic();    }}

运行结果如下:

在这里插入图片描述

  1. if(name.equals(“jiejie”){}这段代码有问题么?怎么优化?

    答:有问题。name可能为null,那么就会报空指针异常。代码改为if(“jiejie”.equals(name){}即可避免该异常。

  2. 接口和抽象类有什么区别?

    答:抽象类要被子类继承,接口要被类实现,抽象类既可以声明方法又可以实现方法,接口只能声明方法。抽象类可以有构造函数,但是不能被实例化,接口没有构造函数也不能被实例化。抽象类里定义的变量是普通变量,而接口里定义的变量一定要是常量。类只能单继承抽象类,但是类可以多实现接口。抽象类是重构的结果,接口是设计的结果。

  3. 说说抽象类不能被实例化,为什么还要有构造方法?

    答:首先要明白抽象类是需要被子类继承,才能够被使用。而在子类继承了抽象类,可以在自己的构造器里通过 super()方法先初始化父类抽象类里的属性。参考代码如下:

有一个抽象类AbstractTest

public abstract class AbstractTest {       public int a;        //无参构造函数     public AbstractTest() {       }        //有参构造函数     public AbstractTest(int a) {           this.a = a;    }}

有一个类TestMain继承AbstractTest类:

public abstract class TestMain extends AbstractTest {       //无参构造函数     public TestMain() {       }    //有参构造函数     public TestMain(int a) {           super(a);    }}

可以看到抽象类有参的构造函数,在子类的相同参数列表的构造函数里默认被调用,完成父类属性初始化的工作。

  1. 抽象类会用到构造函数初始化属性,那么为什么接口却没有构造函数?

    答:因为接口里定义的变量都必须是常量,会被放在常量池中,不需要初始化。

  2. 为什么抽象类,接口无法实例化?

    答:首先抽象类里可能会有抽象方法,抽象方法是没有方法体的。这样JVM没有办法为抽象类分配具体的内存空间,所以出于安全考虑,Java规定抽象类,接口无法实例化。

转载地址:http://hgcp.baihongyu.com/

你可能感兴趣的文章
LiveGBS user/save 逻辑缺陷漏洞复现(CNVD-2023-72138)
查看>>
localhost:5000在MacOS V12(蒙特利)中不可用
查看>>
logstash mysql 准实时同步到 elasticsearch
查看>>
Luogu2973:[USACO10HOL]赶小猪
查看>>
mabatis 中出现< 以及> 代表什么意思?
查看>>
Mac book pro打开docker出现The data couldn’t be read because it is missing
查看>>
MAC M1大数据0-1成神篇-25 hadoop高可用搭建
查看>>
mac mysql 进程_Mac平台下启动MySQL到完全终止MySQL----终端八步走
查看>>
Mac OS 12.0.1 如何安装柯美287打印机驱动,刷卡打印
查看>>
MangoDB4.0版本的安装与配置
查看>>
Manjaro 24.1 “Xahea” 发布!具有 KDE Plasma 6.1.5、GNOME 46 和最新的内核增强功能
查看>>
mapping文件目录生成修改
查看>>
MapReduce程序依赖的jar包
查看>>
mariadb multi-source replication(mariadb多主复制)
查看>>
MariaDB的简单使用
查看>>
MaterialForm对tab页进行隐藏
查看>>
Member var and Static var.
查看>>
memcached高速缓存学习笔记001---memcached介绍和安装以及基本使用
查看>>
memcached高速缓存学习笔记003---利用JAVA程序操作memcached crud操作
查看>>
Memcached:Node.js 高性能缓存解决方案
查看>>