零基础学 Java
臧萌
PayPal 数据处理组技术负责人
46665 人已学习
新⼈⾸单¥68
课程目录
已完结/共 170 讲
第二章 Java面向对象编程 (74讲)
时长 07:13
时长 12:08
时长 06:26
时长 05:30
时长 14:16
时长 08:30
零基础学 Java
登录|注册
留言
8
收藏
沉浸
阅读
分享
手机端
回顶部
当前播放: 86 | hashCode和equals 方法(下)
00:00 / 00:00
高清
  • 高清
1.0x
  • 2.0x
  • 1.5x
  • 1.25x
  • 1.0x
  • 0.75x
  • 0.5x
网页全屏
全屏
00:00
付费课程,可试看
01 | 课程介绍
02 | 内容综述
03 | 开发环境搭建(macOS)
04 | HelloWorld程序编译和运行(macOS)
05 | 开发环境搭建(Windows)
06 | HelloWorld程序编译和运行(Windows)
07 | 详解HelloWorld程序
08 | IntelliJ IDEA集成开发环境的安装和使用(macOS)
09 | IntelliJ IDEA集成开发环境的安装和使用(Windows)
10 | 从加减乘除到变量
11 | 再探计算加减乘除的程序
12 | Java中的基本数据类型
13 | Java中的运算符
14 | Java中的位运算符
15 | 基本数据类型的更多语法点
16 | 字符集编码和字符串
17 | 操作符和数据类型总结
18 | 程序执行流程之if-else语句(上)
19 | 程序执行流程之if-else语句(下)
20 | 程序循环之for语句
21 | 代码块和变量的作用域
22 | 程序循环之while语句
23 | 程序执行流程之switch语句
24 | 循环和判断的总结(上)
25 | 循环和判断的总结(下)
26 | 用数组保存成绩
27 | 认识变量和数组(上)
28 | 认识变量和数组(下)
29 | 多维数组
30 | 用数组灵活处理程序
31 | 类(class)
32 | 初探类和对象
33 | 认识引用类型(上)
34 | 认识引用类型(下)
35 | 类、对象和引用的关系
36 | 认识数组类型
37 | 引用的缺省值null
38 | 像自定义类型一样使用类
39 | Java中的包和访问修饰符(上)
40 | Java中的包和访问修饰符(下)
41 | 打造一个小超市
42 | IntelliJ调试程序初探
43 | 方法:让Merchandise对象有行为
44 | 返回值:让Merchandise计算毛利润
45 | 参数:让Merchandise计算多件商品的总价
46 | 参数和返回值是怎么传递的
47 | 分清参数、局部变量和实例的地盘
48 | 隐藏的this自引用
49 | 理解方法:一种特殊的代码块
50 | 理解方法的调用:代码的一种特殊跳转
51 | 给类和方法加Java注释
52 | 成熟的类的对象要自己做事情
53 | 方法的签名和重载
54 | 重载的参数匹配规则
55 | 构造方法:构造实例的方法
56 | 构造方法的重载和互相调用
57 | 静态变量
58 | 静态方法
59 | 静态方法的重载
60 | static代码块和static变量初始化
61 | 方法和属性的可见性修饰符
62 | 重新认识老朋友:Math和Scanner(上)
63 | 重新认识老朋友:Math和Scanner(下)
64 | 最熟悉的陌生人:String (上)
65 | 最熟悉的陌生人:String (下)
66 | 重新认识老朋友: main方法和System类
67 | String类的好兄弟
68 | 继承:方便让商品增加新的类别
69 | 子类对象里藏着一个父类对象
70 | 覆盖:子类想要一点不一样
71 | super:和父类对象沟通的桥梁
72 | super:调用父类的构造方法
73 | 父类和子类的引用赋值关系
74 | 多态:到底调用的哪个方法?(上)
75 | 多态:到底调用的哪个方法?(下)
76 | 多态里更多的语法点(上)
77 | 多态里更多的语法点(下)
78 | instanceof操作符
79 | 继承专属的访问控制:protected
80 | final修饰符(上)
81 | final修饰符(下)
82 | 继承里的静态方法
83 | 插曲:for循环的另一种写法
84 | 万类之祖:Object类
85 | hashCode和equals 方法(上)
86 | hashCode和equals 方法(下)
87 | toString方法
88 | 初探Class类
89 | 初探反射(上)
90 | 初探反射(下)
91 | 面向对象三要素:封装、继承和多态
92 | 枚举:定义商品的门类
93 | 接口:让商品类型更丰富(上)
94 | 接口:让商品类型更丰富(下)
95 | 抽象类:接口和类的混合体
96 | 有方法代码的接口
97 | 接口内代码的更多内容
98 | 静态内部类
99 | 成员内部类
100 | 局部内部类
101 | 匿名类
102 | 特殊类的总结
103 | 让我们的超市运转起来:设计篇
104 | 让我们的超市运转起来:代码篇
105 | 初识异常:try catch
106 | Java中异常的分类
107 | 抛出异常的语法
108 | Java异常的传递
109 | 自定义异常
110 | 异常传递不是凌波微步
111 | try catch finally语句
112 | 自动回收资源的try语句
113 | Java中的常见异常
114 | Collection类族简介
115 | Collection中的List (上)
116 | Collection中的List(下)
117 | Collection中的Set
118 | 泛型简析(上)
119 | 泛型简析(下)
120 | 再探泛型
121 | Iterator接口
122 | Map:key和value的映射
123 | 定义自己的注解
124 | Lambda V.S. 匿名类(上)
125 | Lambda V.S. 匿名类(下)
126 | 基本类型的自动装箱和拆箱
127 | Java中的File类
128 | Java I/O简介
129 | 写文件内容小程序
130 | 读文件内容小程序
131 | 网络通讯名词简介
132 | 简单的网络通讯小程序(上)
133 | 简单的网络通讯小程序(下)
134 | 简单的抓取网页内容的程序
135 | JDK和JRE
136 | 初识线程
137 | 创建自己的线程
138 | 再探线程
139 | 多线程:混乱开始了
140 | 同步控制之synchronized
141 | 同步控制之wait notify
142 | 多线程经典模型:生产者消费者
143 | 线程同步之join
144 | 死锁
145 | ThreadLocal线程专属的变量
146 | 定时任务
147 | volatile关键字的作用
148 | concurrent包基本原理
149 | concurrent包中的Atomic类族
150 | concurrent包中的锁
151 | concurrent包中的数据结构
152 | concurrent包中的线程池
153 | 聊天室开张喽 (上)
154 | 聊天室开张喽 (下)
155 | 什么是学习一门语言
156 | Java平台简介
157 | Maven概念简介
158 | Maven的安装和配置
159 | 创建一个简单的Maven项目
160 | 一个从pptx文件中抽取文字的小工具
161 | Maven常用命令和插件
162 | Intellij更多功能介绍
163 | 值得学习的类库简介
164 | 如何在Stack Overflow上提问才不会被骂
165 | 浅谈程序设计
166 | 游戏小程序功能定义
167 | 游戏小程序设计和模块划分
168 | 游戏小程序代码分析
169 | 使用Swagger创建一个Spring Boot的Web服务
170 | 结课测试&结束语
本节摘要

PDF 课件和源代码下载地址:
https://gitee.com/geektime-geekbang/LetsJava

登录 后留言

全部留言(8)

  • 最新
  • 精选
~~
我试了一下,好像用输入的方式S1==S2就是false,不管输入的长短都是false,如果直接赋值的话就算是特别长也是true

作者回复: 这是Java虚拟机对字符串的优化,具体的行为可能是因不同的jdk版本而不同。

2019-10-20
7
未成年
老师你好, 我在一个空的class(这个类只有默认构造函数)中重写equals 方法时候generator 并没有生成hascode。这是不是意味着java中空的class的实例对象永远不会相等?

作者回复: 从道理上讲,如果一个class直接继承Object,然后又没有任何属性,那这个类除了类名之外,其实就是Object类嘛。所以不能生成有意义的hashcode和equals也是合理的。因为是在没有逻辑可以做。

2020-06-23
2
Geek_74f419
s1="abc"; s2="abc"; String s3=new String("abc") String s4=new String("abc") 首先要明白在java中,内存中分为类栈内存和堆内存,栈内存主要放基本数据类型的(比如char、int等)堆内存存放方法,对象等。 java在读程序过程读到第一句s1="abc"时,会在栈内存中创建一个s1,然后寻找栈内是否已经存在有abc字符串;明显没有,然后就在栈内存中创建abc字符串,将s1引向这个abc,然后读第二段s2="abc",一样的,会先在栈内存创建一个s2,然后寻找栈内存中是否已经有现成的abc字符串,明显已经有了(就是上一句代码s1=“abc”;创建的),这时由于java出于内存优化(降低内存资源占用),就不会再在栈内存中创建一个同样的abc字符串,而是直接将s2引用直接指向栈内存中已经存在的abc字符串。所以你再用s1==s2去判断时,因为都是指向栈内存中的同一个内存位置,所以必然是true。 然后电脑读第三句代码String s3=new String("abc"),这个new出来的是一个String类的对象,而对象都是存在内存中的,而且每一个对象都是在堆内存中分开存放的,这个时候,虽然在s3对象中的值也是字符串abc,但是其引用指向的位置却不是栈内存中已经存在的字符串abc的位置,而是堆内存中专门为s3开辟的一块堆内存中的位置;这时候你用s1==s3,因为两个一个指向的栈内存中的abc位置,一个指向堆内存中的s3的abc位置,必然为false; 同理,第四句String s4=new String("abc"),也是在堆内存中创建了一个单独的s4的专属内存区域,就和老师前边讲的每个对象订一个本子一样,s4和s3完全是在堆内存中的两个本子,所以即使都是s3和s4的值都是字符串abc,但是引用位置却不同,所以s3==s4也就为false; 综上所述s1==s2//true; s1==s3||s2==s3||s1==s4||s2==s4||s3==s4//false; 然后就还有虚拟机涉及到一个存放字符串过程的东西实际上abc也是先生成的char a b c,然后再组合的,内容就太多了,可以去看下资料

作者回复: 👍 👍,你完全get了 https://xie.infoq.cn/article/38f5ad03242b79b46e30bfa1b

2021-11-23
1
未聞花名
看源码 nextline方法里面调用的是subString 返回的都是一个新的String对象,所以 == 判断都是false

作者回复: 这个也看JDK具体的实现和优化。因为String太常用了,JVM是有缓存优化的。String的intern方法,可以将一个String加入缓存,完全相同的String,JVM会直接从缓存里返回,不会创建新的实例,即使是new String。 这里讲解equals和==的区别,用String是略有不妥的,原因就是上面这些复杂的原因。但是String是对象,但是其内容又简单可读,所以用String举例子比较简单直观。

2020-10-05
1
Bo
第一次运行时,打乱对String的优化的输出第一行是false,没有"s1和s2用==判断结果",是因为运算符优先级:+ > ==

作者回复: ✅✅

2023-01-24
森森
hasCode()方法的主要应用场景是什么?好像没看到老师介绍?只是说hasCode相等,不一定equal相等,是因为hasCode只是对引用进行了比较,而没有对成员变量进行比较,所以不具有绝对相等性么?

作者回复: hashcode只是对比了特征值,就好像人的名字一样。

2020-03-29
Mr.z
源代码: @Test public void test() { scanner = new Scanner(System.in); System.err.println("请输入str1"); String str1 = scanner.nextLine(); System.err.println("请输入str2"); String str2 = scanner.nextLine(); System.err.println("str1 == str2 :" + (str1 == str2)); System.err.println("str1 equals str2 :" + (str1.equals(str2))); } 执行结果: 请输入str1 abc 请输入str2 abc str1 == str2 :false str1 equals str2 :true 之前字符串的比较都是用的equals ,听你说jdk优化了== 所以想测试一下,发现我的执行结果和你的并不一样,哈哈,果然薛定谔的Tomcat。

作者回复: 其实不是jdk优化了==,而是jdk尽力优化了String对象的创建,减少重复创建相同的对象。Integer这些也是一样的

2019-08-01
2
Mr.z
我在eclipse里面使用jdk1.8 192 和 openjdk 11 里面执行程序 == 也是 false ,即便只有一个字符。

作者回复: 源代码来一套看看? 字符串 == 比较确实是和JDK具体的实现先相关的,出于学习的目的可以这么深究一下,但是真正写代码的时候,不要依赖于== 返回true或者false,可以认为 == 的结果是薛定谔的tomcat

2019-07-31
收起评论