Java基础-打卡20230428

本文介绍了Java开发环境JDK、运行环境JRE、虚拟机JVM以及Just-In-Time编译器JIT的概念。同时,讨论了解释性与编译性的区别,以及Java中的移位操作对负数的影响。文章还涉及了包装类型的缓存机制,强调了重写equals和hashCode方法的重要性,以确保散列表的正确行为。最后提到了SPI(ServiceProviderInterface)在服务发现和扩展中的作用。
摘要由CSDN通过智能技术生成

1.JDK - JRE - JVM -JIT

jdk包含jre + 编译器javac,等其他工具javadoc等。可以创建+运行java程序

jre java运行时环境,可以运行java程序,但不能创建编译java程序

jvm java字节码运行虚拟机,java程序运行在虚拟机上

JIT .class - > 机器码,运行时编译

2. 解释性和编译性

解释性,一次性将代码翻译成机器语言

编译性,一句一句将代码翻译成机器语言

3 移位

负数存储的是补码,左移*2,右移 / 2

4. 包装类型有缓存机制,Integer,Byte,Short,Long [-128,127],Charactor[0,127]. Boolean TRUE/FALSE

5 hashcode和equals方法

  • 如果两个对象相同(即用equals比较返回true),那么它们的hashCode值一定要相同;性能以及语义
  • 如果两个对象的hashCode相同,它们并不一定相同(即用equals比较返回false)

创建对象的散列表时,才会用到hashcode

如果重写equals,不重写hashcode,则会出现不相同hashcode【不等的key】,但是equals相等的对象在散列表中,数据重复

如果重写hashcode,不重写equals,则会出现不同的hashcode-【不等的key】,但是逻辑上相等的对象在散列表中重复,hashset。

实际上,一般来说,hashcode相等,equals不相等的哈希冲突还能忍受,但是equals相等造成hashcode不相等,造成HashSet存放相同是一定不能忍受的,就是说,重写equals放宽return true的同时一定要重写hashcode放宽return 哈希码。

6.SPI 即 Service Provider Interface 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值