1. hashCode 与 equals的基本概念?HashSet如何检查重复?两个对象的 hashCode() 相同,则 equals() 也一定为 true是吗?hashCode和equals方法的关系
hashCode()的基本概念:
hashCode() 的作用是获取哈希码,也称为散列码;它实际上是返回一个int整数。这个哈希码的作用是确定该对象在哈希表中的索引位置。hashCode() 定义:在JDK的Object.java中,这就意味着Java中的任何类都包含有hashCode()函数。 散列表存储的是键值对(key-value),它的特点是:能根据“键”快速的检索出 对应的“值”。这其中就利用到了散列码!(可以快速找到所需要的对象)为什么要有hashCode?或者说是HashSet如何去重复元素?
当你把对象加入 HashSet 时,HashSet 会先计算对象的 hashcode 值来判断对象加入的位置,同时也会与其它已经加入的对象的 hashcode 值作比较,如果没有相符的hashcode,HashSet会假设对象没有重复出现。但是如果发现有相同 hashcode 值的对象,这时会调用 equals()方法来检查 hashcode 相等的对象是否真的相同。如果两者相同,HashSet 就不会让其加入操作成功。如果不同的话,就会重新散列到其他位置。这样我们就大大减少了 equals 的次数,相应就大大提高了执行速度。问:面试官可能会问你:“你重写过 hashcode 和 equals 么,为什么重写equals时必须重写hashCode方法?”
答:为了确保:当我们用equals方法得到两对象相等时,则它们的hashCode也相等。hashCode()与equals()的相关规定
如果两个对象相等,则hashcode一定也是相同的。两个对象相等,两个对象分别调用equals方法都返回true。但是如果两个对象有相同的hashcode值,它们是不一定相等的。因此,equals 方法被覆盖过,则 hashCode 方法也必须被覆盖。
2.成员变量和局部变量的存储位置?
成员变量:随着对象的创建而存在,随着对象的消失而消失,存储在堆内存中。
局部变量:在方法被调用,或者语句被执行的时候存在,存储在栈内存中。当方法调用完,或者语句结束后,就自动释放。
3.静态变量和实例变量区别?
静态变量: 静态变量由于不属于任何实例对象,属于类的,所以在内存中只会有一份,在类的加载过程中,JVM只为静态变量分配一次内存空间。
实例变量: 每次创建对象,都会为每个对象分配成员变量内存空间,实例变量是属于实例对象的,在内存中,创建几次对象,就有几份成员变量。
4.构造器是否可被重写?
构造器不能被继承,因此不能被重写,但可以被重载。
5.try-catch-finally 中,如果 catch 中 return 了, finally 还会执行吗?
- 会执行,在 return 前执行。在 finally 中改变返回值的做法是不好的,因为如果存在 finally 代码块, try中的 return 语句不会立马返回调用者,而是记录下返回值待 finally 代码块 执行完毕之后再向调用者返回其值,然而如果在 finally 中修改了返回值,就会返回修改后的值。
- 在 finally 中返回或者修改返回值会对程序造成很大的困扰,Java中通过提升编译器的语法检查级别来产生警告或错误。
6. Java 和 C++的区别?
都是面向对象的语言,都支持封装、继承和多态。
Java 不提供指针来直接访问内存,程序内存更加安全,C++是可以直接访问内存的。
Java 的类是单继承的,C++ 支持多重继承;虽然 Java 的类不可以多继承,但是接口可以多继承。
Java 有自动内存管理机制,不需要程序员手动释放无用内存,C++必须手动释放内存。
好了,关于【Java基础面试知识你真的掌握了吗?】就先学习这么多,基础的面试也需要掌握的很扎实哟!