标签:排序 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上:
? ? ? ?强引用:如果一个对象具有强引用,它就不会被垃圾回收器回收。即使当前内存空间不足,JVM也不会回收它,而是抛出 OutOfMemoryError 错误,使程序异常终止。如果想中断强引用和某个对象之间的关联,可以显式地将引用赋值为null,这样一来的话,JVM在合适的时间就会回收该对象。
? ? ? ?软引用:在使用软引用时,如果内存的空间足够,软引用就能继续被使用,而不会被垃圾回收器回收,只有在内存不足时,软引用才会被垃圾回收器回收。
? ? ? ?弱引用:具有弱引用的对象拥有的生命周期更短暂。因为当 JVM 进行垃圾回收,一旦发现弱引用对象,无论当前内存空间是否充足,都会将弱引用回收。不过由于垃圾回收器是一个优先级较低的线程,所以并不一定能迅速发现弱引用对象。
? ? ? ?虚引用:顾名思义,就是形同虚设,如果一个对象仅持有虚引用,那么它相当于没有引用,在任何时候都可能被垃圾回收器回收。
虽然 WeakReference 与 SoftReference 都有利于提高 GC 和 内存的效率,但是 WeakReference ,一旦失去最后一个强引用,就会被 GC 回收,而软引用虽然不能阻止被回收,但是可以延迟到 JVM 内存不足的时候。
不像C语言,我们可以控制内存的申请和释放,在Java中有时候我们需要适当的控制对象被回收的时机,因此就诞生了不同的引用类型,可以说不同的引用类型实则是对GC回收时机不可控的妥协。有以下几个使用场景可以充分的说明:
利用软引用和弱引用解决OOM问题:用一个HashMap来保存图片的路径和相应图片对象关联的软引用之间的映射关系,在内存不足时,JVM会自动回收这些缓存图片对象所占用的空间,从而有效地避免了OOM的问题.
? ? ? ?通过软引用实现Java对象的高速缓存:比如我们创建了一Person的类,如果每次需要查询一个人的信息,哪怕是几秒中之前刚刚查询过的,都要重新构建一个实例,这将引起大量Person对象的消耗,并且由于这些对象的生命周期相对较短,会引起多次GC影响性能。此时,通过软引用和 HashMap 的结合可以构建高速缓存,提供性能。
==是运算符,比较两个变量是否相等,而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域,这两个操作之间不能重排序
标签:排序 mem 包装 性能 相同 面试题 错误 使用场景 多层嵌套循环
原文地址:https://blog.51cto.com/14801695/2498321