【测开面试题】八股文总结

测开面试八股文:Java、数据结构等总结

🎄Java基础

1. Java数据类型

基本数据类型:byte,char,short,int,float,double,long,boolean

引用数据类型:class,Arrays,interface

Python基本数据类型:int,float,str,bool

2. 理解面向对象

面向对象是利于语言对现实事物进行抽象。面向对象具有以下四大特征:

(1)继承:继承是从已有类得到继承信息创建新类的过程

(2)封装:通常认为封装是把数据和操作数据的方法绑定起来,对数据的访问只能通过已定义的接口。

(3)多态性:多态性是指允许不同子类型的对象对同一消息作出不同的响应。

(4)抽象:抽象是将一类对象的共同特征总结出来构造类的过程,包括数据抽象和行为抽象两方面。

3. ==和Equals的区别

==:

如果比较的是基本数据类型,那么比较的是变量的值

如果比较的是引用数据类型,那么比较的是地址值(两个对象是否指向同一块内存)

Equals:

如果没重写equals方法比较的是两个对象的地址值

如果重写了equals方法后我们往往比较的是对象中的属性的内容

equals方法是从Object类中继承的,默认的实现就是使用==

4. String,String buffer和String builder区别

(1)String是不可变的,String buffer,String builder是可变的;所谓不可变,任何修改操作都要重新创建对象,不能直接修改;

(2)String线程安全(因为不可变,天然线程安全),String buffer线程安全(加锁synchronized),String builder线程不安全;

(3)String一般作为字符串常量使用,在单线程程序下,StringBuilder效率更快,因为它不需要加锁,不具备多线程安全而StringBuffer则每次都需要判断锁,效率相对更低

5. final关键字

final作为Java中的关键字可以用于三个地方。用于修饰类、类属性和类方法。

特征:凡是引用final关键字的地方皆不可修改!

(1)修饰类:表示该类不能被继承;

(2)修饰方法:表示方法不能被重写;

(3)修饰变量:表示变量只能一次赋值以后值不能被修改(常量)。

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

(1)关键字:抽象类通过abstract定义,接口通过interface定义

(2)方法实现:抽象类可以有具体的方法和抽象方法,接口在java 8前只能有抽象方法,之后可以有默认的方法和静态方法

(3)成员变量:抽象类可以有普通的成员变量,接口只能是public static final修饰(常量)

(4)构造方法:抽象类有构造方法,接口没有构造方法

(5)多继承:抽象类一个类只能继承一个抽象类,接口一个类可以实现多个接口

(6)访问修饰符:抽象类的方法可以是任意访问修饰符,接口的方法默认是public

7. 重载和重写的区别

(1)重载发生在本类,重写发生在父类与子类之间

(2)重载的方法名必须相同,重写的方法名相同且返回值类型必须相同

(3)重载的参数列表不同,重写的参数列表必须相同

(4)重写的访问权限不能比父类中被重写的方法的访问权限更低

(5)构造方法不能被重写

8. 什么是自动装拆箱 int和Integer区别

基本数据类型,如int,float,double,boolean,char,byte,不具备对象的特征,不能调用方法。

(1)装箱:将基本类型转换成包装类对象

(2)拆箱:将包装类对象转换成基本类型的值

java为什么要引入自动装箱和拆箱的功能?

主要是用于java集合中,List<Inteter> list=new ArrayList<Integer>();

list集合如果要放整数的话,只能放对象,不能放基本类型,因此需要将整数自动装箱成对象。

区别:

 (1)Integer是int的包装类,int则是java的一种基本数据类型

(2)Integer变量必须实例化后才能使用,而int变量不需要

(3)Integer实际是对象的引用,当new一个Integer时,实际上是生成一个指针指向此对象;而int则是直接存储数据值

(4)Integer的默认值是null,int的默认值是0 

🌲数据结构

1.  ArrayList和LinkedList的区别

(1)ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构。

(2)对于随机访问get和set,ArrayList觉得优于LinkedList,因为LinkedList要移动指针。

(3)对于新增和删除操作add和remove,LinkedList比较占优势,因为ArrayList要移动数据。 这一点要看实际情况的。若只对单条数据插入或删除,ArrayList的速度反而优于LinkedList。但若是批量随机的插入删除数据,LinkedList的速度大大优于ArrayList. 因为ArrayList每插入一条数据,要移动插入点及之后的所有数据。

2. HashMap和HashTable区别

 (1)线程安全性不同

HashMap是线程不安全的,HashTable是线程安全的,其中的方法是Synchronized,在多线程并发的情况下,可以直接使用HashTable,但是使用HashMap时必须自己增加同步处理。

 (2)是否提供contains方法

HashMap只有containsValue和containsKey方法;HashTable有contains、containsKey和containsValue三个方法,其中contains和containsValue方法功能相同。

(3) key和value是否允许null值

Hashtable中,key和value都不允许出现null值。HashMap中,null可以作为键,这样的

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值