Java中常见的区别。
this与super的区别:
this | super |
---|---|
当前对象的引用 | 父类对象的引用 |
this( ): 调用当前类中其他的构造方法(必须放在第一行) | super( ); 调用父类的构造方法(必须放在第一行) |
this.data:调用当前类中的属性 | super.data: 访问父类的属性 |
this.func: 调用当前类中的成员方法 | super.func: 调用父类的成员方法 |
抽象类和接口的区别:
抽象类中除了抽象方法以外,可以包含普通的属性和方法,这些普通的属性和方法可以被子类直接使用(不用重写)。接口类中只有抽象方法,不能包含普通方法,并且子类必须重写所有的抽象方法。
重写和重载的区别:
重写 | 重载 |
---|---|
方法名相同 | 方法名相同 |
参数列表相同 | 参数列表不同(参数的个数, 类型) |
返回值相同 | 返回值不做要求 |
在不同的类中, 且具有继承的关系 | 在同一个类中 |
String、StringBuilder和StringBuffer的区别:
String和StringBuilder和StringBuffer的区别:
1、String的拼接会产生大量临时变量。StringBuilder和StringBuffer不会。(append返回的是一个this)
2、String拼接会被优化为StringBuilder的append()
3、String和StringBuilder一般用于单线程情况下,StringBuffer一般用于多线程。
3、后两者当中有一些方法是String不具备的。(如逆置方法等)
数组和链表的区别:
数组在内存空间上是连续的,而链表在内存空间上是可以不连续的。其中链表的每个元素存储了下一个元素的地址,使得一系列的随机的内存地址串在一起。所以只要用足够的内存空间,就能为链表分配内存。
数组优于链表: 内存空间占用少,数据可随机访问性,查找速度相对较快。
链表优于数组: 插入和删除的操作优于数组,对内存空间的利用率较高,并且链表的可扩展性高于数组。
数组的优缺点:优点:使用方便,查询效率比链表高,内存是连续的空间
缺点:大小固定,不适合动态存储,不方便动态添加;
链表:优点:可以动态删除,大小可变
缺点:只能通过顺时针指针去访问,查询效率低
链表和数组的本质差异
1、 在访问方式上
数组可以随机访问其中的元素。
链表则必须是顺序访问,不能随机访问。
2 、 空间的使用上
链表可以随意扩大。
数组则不能。