🎄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可以作为键,这样的
测开面试八股文:Java、数据结构等总结

最低0.47元/天 解锁文章
1万+

被折叠的 条评论
为什么被折叠?



