面试大厂,90%会被问到的Java面试题(附答案)
2021-01-08 23:34
标签:排序 mem 包装 性能 相同 面试题 错误 使用场景 多层嵌套循环 封装,继承,多态 允许不同类对象对同一消息作出相应,好处如下: 可替换性:多态对已存在的代码具有可替换性 可扩充性:增加新的子类不会影响已经存在的类结构 接口性:多态是超类通过方法签名,向子类提供一个接口,由子类完善或重写来实现 灵活性 简化性 代码中:接口实现,继承父类重写方法,同一类中方法重载 虚拟机中:动态绑定技术(dynamic binding),执行期间判断所引用对象的实际类型,根据实际类型调用对应的方法 接口:规范,拓展,回调 抽象类:为其他子类提供一个公共的类型;封装子类中重复定义个内容;定义抽象方法,子类虽然有不同的实现,但是定义时是一致的 不能。重写只适用于实例方法,不能用于静态方法,而子类当中含有和父类相同签名的静态方法,我们一般称之为隐藏。 不可变对象指对象一旦被创建,状态就不能再改变。任何修改都会创建一个新的对象,如String,Integer等其他包装类。 静态变量存在方法区,属于类所有。实例变量存储在堆中,其引用存在当前线程栈。 可以,需要注意不要共享可变对象的引用,如果需要变化时,就返回原对象的一个拷贝。举例:日期对象。 new,反射,clone(),通过序列化机制 Java7以前不能使用String做参数,可以使用byte,short,char,int及封装类和枚举,Java7之后可以使用String,一直不能用long intern()方法会先从常量池中查询是否存在该常量值,如果不存在则创建,否则直接放回 euqals(),toString(),clone(),wait(),notify(),nofifyAll(),getClass() 强引用,软引用,弱引用,虚引用。不同的引用类型主要体现在GC上: 虽然 WeakReference 与 SoftReference 都有利于提高 GC 和 内存的效率,但是 WeakReference ,一旦失去最后一个强引用,就会被 GC 回收,而软引用虽然不能阻止被回收,但是可以延迟到 JVM 内存不足的时候。 不像C语言,我们可以控制内存的申请和释放,在Java中有时候我们需要适当的控制对象被回收的时机,因此就诞生了不同的引用类型,可以说不同的引用类型实则是对GC回收时机不可控的妥协。有以下几个使用场景可以充分的说明: 利用软引用和弱引用解决OOM问题:用一个HashMap来保存图片的路径和相应图片对象关联的软引用之间的映射关系,在内存不足时,JVM会自动回收这些缓存图片对象所占用的空间,从而有效地避免了OOM的问题. ==是运算符,比较两个变量是否相等,而equals是Object类的方法,用来比较两个对象是否相等。 默认equals方法比较两个对象的地址,此时结果相同,如果要比较内容,则要重写equals方法 hashcode()是Object类的一个方法,返回一个hash值,如果equals()相同则hashcode()相同,反之不然。 有可能,两个不相等的对象可能有相同的hashcode值,只就是hashmap中会有冲突,如果对象相等,则hashcode相等,反之不然 不可以,hashcode必须是相同的值 如果a和b都是对象,a==b比较的是引用,只有当a和b指向堆中同一个对象才会返回true,而a.equals(b)进行逻辑比较,通常呀哦重写该方法提供逻辑性一个的比。 false,因为有些浮点数不能精确的表示出来 += 操作符会隐式转换,例如下题 有错误,s1 = (short)(s1+1); +=操作符会自动对右边的表达式结果强转匹配左边的数据类型,所以没错 前者是位操作,后者是逻辑运算符 一个Java内部只能有一个public的类,可以有多个default的类 使用标号和break; 内部类提供了更好的封装,除了该外围类,其他类都不能访问 fianl是一个修饰符,可以修饰类,方法,变量的。finally是一个关键字,捕获异常是与try连用的,一定会执行。finalize是在对象被回收之前调用的方法,给对象自己最后一个复活的机会,但是什么时候调用finalize没有保证 java.lang.Cloneable的一个标示性接口,不包含任何方法,clone方法在object中定义,clone()方法是一个本地方法,是由c或c++实现的 浅拷贝:仅仅复制所考虑的对象,而不复制它引用的对象 深拷贝:所有的对象都复制 静态变量和静态方法,被类实例所共享。 静态块,初始化操作。 修饰内部类,为静态内部类 导包,指定导入某个类中的静态资源,并且不需要使用类名 被final修饰的方法不能被继承,修饰的方法不能被重写,修饰的变量不能被改变。被final修饰的方法,JVM会尝试将其内关联,以提高运行效率,被修饰的变量会在编译阶段存在常量池中。 编译器对final域要遵守两个重排规则: 1,在构造器内对一个final域的写入,与随后把这个构造对象的引用赋值给一个引用变量,这两个操作之间不能重排序 2,初次读一个包含final域对象的引用,与随后初次读这个final域,这两个操作之间不能重排序 面试大厂,90%会被问到的Java面试题(附答案) 标签:排序 mem 包装 性能 相同 面试题 错误 使用场景 多层嵌套循环 原文地址:https://blog.51cto.com/14801695/2498321多态的好处,代码中如何实现多态,虚拟机中如何实现多态
接口的意义,抽象类的意义
父类的静态方法能否被子类重写
什么是不可变对象
静态变量和实例变量的区别
能否创建一个包含可变对象的不可变对象
Java创建对象的几种方式
Switch能否使用String做参数,能否作用在byte,long上
说说string的intern()方法
Object有哪些公用方法
Java中的四种引用
? ? ? ?强引用:如果一个对象具有强引用,它就不会被垃圾回收器回收。即使当前内存空间不足,JVM也不会回收它,而是抛出 OutOfMemoryError 错误,使程序异常终止。如果想中断强引用和某个对象之间的关联,可以显式地将引用赋值为null,这样一来的话,JVM在合适的时间就会回收该对象。
? ? ? ?软引用:在使用软引用时,如果内存的空间足够,软引用就能继续被使用,而不会被垃圾回收器回收,只有在内存不足时,软引用才会被垃圾回收器回收。
? ? ? ?弱引用:具有弱引用的对象拥有的生命周期更短暂。因为当 JVM 进行垃圾回收,一旦发现弱引用对象,无论当前内存空间是否充足,都会将弱引用回收。不过由于垃圾回收器是一个优先级较低的线程,所以并不一定能迅速发现弱引用对象。
? ? ? ?虚引用:顾名思义,就是形同虚设,如果一个对象仅持有虚引用,那么它相当于没有引用,在任何时候都可能被垃圾回收器回收。WeakReference与SoftReference的区别
为什么要有不同的引用类型
? ? ? ?通过软引用实现Java对象的高速缓存:比如我们创建了一Person的类,如果每次需要查询一个人的信息,哪怕是几秒中之前刚刚查询过的,都要重新构建一个实例,这将引起大量Person对象的消耗,并且由于这些对象的生命周期相对较短,会引起多次GC影响性能。此时,通过软引用和 HashMap 的结合可以构建高速缓存,提供性能。Java中==和equals()的区别,equals()和hashcode()的区别及联系
有没有可能两个不相等的对象有相同的hashcode
可以在hashcode中使用随机数字吗
a==b与a.equals(b)有什么区别
3*0.1==0.3返回值是什么
a=a+b与a+=b有什么区别吗
short s1 = 1;s1 = s1 +1;该代码是否有错误,如果有错误怎么修改
short s1 = 1;s1+= 1是否有错误,如果有错误怎么修改
&与&&的区别
一个Java内部可以有类?(非内部类)
如何正确的退出多层嵌套循环
内部类的作用
final,finally,finalize的不同之处
clone()是哪个类的方法
深拷贝和浅拷贝的区别是什么
static有哪些用法
final有哪些用法