博客
关于我
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/

你可能感兴趣的文章
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
查看>>
NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
查看>>
NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
查看>>
NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
查看>>
NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
查看>>
NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
查看>>