java中==和equals理论联系实际的坑你踩了吗?剑指 Offer 59 - II. 队列的最大值

简介:  一个阳光明媚的下午,小王正在无所事事的学习,突然微信被一位朋友连环call,原来朋友被一道leetcode给困住了,本着见到bug就想解决掉的冲动,我毫不犹豫的就接了下来。

  一个阳光明媚的下午,小王正在无所事事的学习,突然微信被一位朋友连环call,原来朋友被一道leetcode给困住了,本着见到bug就想解决掉的冲动,我毫不犹豫的就接了下来。


  情况是这样的:


image.pngimage.png


中间的图片放大来看:


55.png



完整的代码:


image.png

为了方便展示我把leetcode的原问题贴过来:

6.png


小伙伴被困在了pop_front方法的具体实现上:


public int pop_front() {
        if (q.isEmpty()) {
            return -1;
        }       
        if (q.peek() == d.peekFirst()) {
            d.pollFirst();
        }
        int ans = q.poll();
        return ans;
}


看上去没有任何问题啊是不是!而且和官方答案很像:


public int pop_front() {
        if (q.isEmpty()) {
            return -1;
        }
        int ans = q.poll();
        if (ans == d.peekFirst()) {
            d.pollFirst();
        }
        return ans;
}


看起来只不过是单单把q.peek()的值给拿出来了而已,然而事实上却不是这样,比如我给你加几条输出语句:


6.png



我们会发现一个“奇怪”的现象,868和868竟然是不相同的,其实这里已经可以看出来了,明明相同的两个值用 == 号判断出来的结果却是false,唯一一种解释就只能是地址不同 。

于是只用做一个很容易的操作就是把Integer转成int就可以AC:



7.png


至于为什么46和46相等,原因还在于Integer的缓存机制,后面会讲。


 至此,相信每一个接触过java准备找工作的同学都背过==和equals的区别,甚至倒背如流,但理论只有在实际生产中使用时才是我们学习理论的最终意义,做一个背书机器在我个人看来意义不大。


最后再来总结一下 == 和 equals 的区别,小伙伴们可以温习一遍:


 ==的作用是判断两个对象的地址是不是相等。即判断两个对象是不是同一个对象。(基本数据类型==比较的是值,引用数据类型==比较的是内存地址)。



 equals的作用也是判断两个对象是否相等。但它一般有两种使用情况:


类没有覆盖 equals方法。则通过equal 比较该类的两个对象时,等价于通过==比较这两个对象。

类覆盖 equals()方法。一般我们都通过覆盖equals方法来判断两个对象的内容是否相等;

 需要注意的是Integer类中有一个静态内部类IntegerCache,在IntegerCache类中有一个lnteger数组,用以缓存当数值范围为-128~127时的Integer对象,IntegerCache固定了缓存的下限,但是上限可以通过设置jdk的AutoBoxCacheMax参数调整,自动缓存区间设置为【-128,N】;所以当我们定义两个Integer的范围在【-128—+127】之间,并且值相同的时候,用==比较值为true;当大于127或者小于-128的时候即使两个数值相同,会new一个integer,那么比较的就是两个对象,用“=="比较的时候返回false。


相关文章
|
算法 Java
7.Java判断和循环+面试相关力扣算法题详解
7.Java判断和循环+面试相关力扣算法题详解
163 1
|
7月前
剑指 Offer 30. 包含min函数的栈
剑指 Offer 30. 包含min函数的栈
38 0
|
6月前
|
Java
杭电 OJ 1010-1019 Java解法(未更新完毕)
杭电 OJ 1010-1019 Java解法(未更新完毕)
29 1
|
7月前
剑指 Offer 30:包含min函数的栈
剑指 Offer 30:包含min函数的栈
48 0
|
存储
LeetCode155|剑指 Offer 30. 包含 min 函数的栈
调用 min、push 及 pop 的时间复杂度都是 O(1) 因此实现一个能够得到栈的最小元素的 min 函数,我们就不能使用for等循环去查找,直接去排序大可不必,所以我们可以通过创建另一个栈,专门去存储每次比较的最小值。
34 0
踩坑-判断Integer相等
踩坑-判断Integer相等
|
存储 算法
【刷题记录】stack queue的题目练习(上)
【刷题记录】stack queue的题目练习(上)
【刷题记录】stack queue的题目练习(下)
【刷题记录】stack queue的题目练习(下)
剑指 Offer 45. 把数组排成最小的数 Java自定义排序
输入一个非负整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。
|
存储
图解LeetCode——剑指 Offer 30. 包含min函数的栈
图解LeetCode——剑指 Offer 30. 包含min函数的栈
83 0