Java面试题总结1

九种基本数据类型的大小,以及它们的封装类:

注:

1.int是基本数据类型,Integer是int的封装类,是引用类型。int默认值是0,而Integer默认值是null,所以Integer能区分出0和null的情况。一旦java看到null,就知道这个引用还没有指向某个对象,再任何引用使用前,必须为其指定一个对象,否则会报错。

2.基本数据类型在声明时系统会自动给它分配空间,而引用类型声明时只是分配了引用空间,必须通过实例化开辟数据空间之后才可以赋值

数组对象也是一个引用对象,将一个数组赋值给另一个数组时只是复制了一个引用,所以通过某一个数组所做的修改在另一个数组中也看的见。

Switch能否用string做参数?

Switch可以用整型,枚举类型,boolean,string类型做参数,但是不能用浮点型。

equals==的区别。

==操作比较的是两个变量的值是否相等,对于引用变量类型表示的是两个变量在堆中的地址是否相同,即栈中的内容是否相同。equals比较的是两个对象的内容。

Object有哪些公用方法

Object是所有类的父类,任何类都默认继承Object类。

Object类的方法:

1.getClass:final方法,获得运行时类型

2.equals:

3.notify()唤醒在此对象监视器上等待的单个线程。

4.notifyAll()唤醒在此对象监视器上等待的所有线程。

5.wait()在其他线程调用此对象的notify()方法或notifyAll()方法前,导致当前线程等待。

6.clone:保护方法,实现对象的浅复制,只有实现了Cloneable接口才能调用该方法,否则抛出CloneNotSupportedException异常。

Java里除了8中基本类型传参数都是值传递,其它类对象传参数都是引用传递,我们有时候不希望在方法里将参数改变,这就需要在类中复写clone方法。

浅复制与深复制

浅复制:被复制对象的所有变量都含有与原来对象相同的值,而所有的对其它对象的引用仍然指向原来的对象。换言之,浅复制仅仅复制所考虑的对象,而不复制它所引用的对象。

深复制:被复制的对象以及该对象所引用的其它对象都复制了一遍。

Java的四种引用,强弱软虚,以及它们用到的场景

参考:my.oschina.net/ydsakyclguozi/blog/404389

强引用:Object o = new Object(),这里o就是一个强引用。如果一个对象具有强引用,即使内存不足,也绝不会被垃圾回收器回收。如果不引用时,使o = null,或超出对象的生命周期范围,就会被gc回收。

软引用:如果一个对象只有软引用,当内存空间足够时,不会被gc回收,当内存空间不足时,会被gc回收。示例:

String str=new String("abc");//强引用

SoftReference softRef=newSoftReference(str);//软引用

弱引用:弱引用与软引用的区别在于:只具有弱引用的对象拥有更短的生命周期。在垃圾回收器线程扫描它所管辖的内存区域的过程中,一旦发现了只具有弱引用的对象,不管当前内存空间足够与否,都会回收它的内存。不过,由于垃圾回收器是一个优先级很低的线程,因此不一定会很快发现那些只具有弱引用的对象。

虚引用:“虚引用”顾名思义,就是形同虚设,与其他几种引用都不同,虚引用并不会决定对象的生命周期。如果一个对象仅持有虚引用,那么它就和没有任何引用一样,在任何时候都可能被垃圾回收器回收。

HashCode的作用:

HashCode的存在主要是为了查找的快捷性,HashCode是用来在散列存储结构中确定对象的存储地址的。如果两个对象的hashCode值不同,则这两个对象一定不同。

ArrayList、LinkedList和Vector的区别:


Collection继承图

LinkedList,ArrayList与Vector的比较:

这三个类都是基于数组实现的List类

LinkedList和ArrayList是线程不安全的,Vector是线程安全的,但是Vector性能差。

ArrayList是一个可改变大小的数组.当更多的元素加入到ArrayList中时,其大小将会动态地增长.内部的元素可以直接通过get与set方法进行访问,因为ArrayList本质上就是一个数组。

LinkedList是一个双链表,在添加和删除元素时具有比ArrayList更好的性能.但在get与set方面弱于ArrayList。

StringStringBufferStringBuilder的区别

String类是不可变类,任何String的改变都会产生一个新的String对象,而StringBuffer和StringBuilder都是可变类。StringBuffer支持并发操作,线程安全,适合多线程使用,StringBuilder不支持并发操作,线程不安全,不支持多线程使用,但StringBuilder速度更快。

MapSetListQueueStack的特点和用法

Map是使用键值对来存储数据,且一一映射,值可以重复,但是键不能。TreeMap可以保证顺序,HashMap则不行。

Set是不包含重复元素的集合,set最多包含一个null元素。

List是有序的可重复集合,可以再任意位置增加和删除元素。

Queue先进先出。

Stack后进先出。

使用建议:如果涉及堆栈,队列等操作,建议使用List;对于快速插入和删除元素的,建议使用LinkedList;如果需要快速随机访问元素的,建议使用ArrayList。

HashMapHashTable的区别:

HashMap可接受值为null,是不同步的,HashTable不能接受值为null,是同步的。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,759评论 18 399
  • (一)Java部分 1、列举出JAVA中6个比较常用的包【天威诚信面试题】 【参考答案】 java.lang;ja...
    独云阅读 7,141评论 0 62
  • 相关概念 面向对象的三个特征 封装,继承,多态.这个应该是人人皆知.有时候也会加上抽象. 多态的好处 允许不同类对...
    东经315度阅读 1,990评论 0 8
  • 01 曾经我的朋友白素跟我讲过一个真实发生的故事: 她有一个好朋友叫陈冰,她们两个人是玩得特别铁的那种。有一次,公...
    徐少寒阅读 10,854评论 115 258
  • 南音烟雨阅读 354评论 12 4