读《疯狂Java讲义》笔记总结三
1.初始化块
实际上初始化块是一个假象,使用javac命令编译Java类后,该Java类中的初始化块会消失——初始化块中代码会被 “还原” 到每一个构造器中,且位于构造器全部代码的前面。
2.p125-p128 自己主动装箱,自己主动拆箱不太懂
3.包装类
4.单例类
实例:
//提供一个静态方法。用于返回Singleton实例 //该方法能够增加自己定义控制。保证仅仅产生一个singleton对象 public static Singleton getInstance() { //假设instance为null。则表明还不曾创建Singleton对象 //假设instance不为null。则表明已经创建了Singleton对象 //将不会又一次创建新的实例 if (instance == null) { //创建一个Singleton对象。并将其缓存起来 instance = new Singleton (); } return instance; }
5.final修饰基本类型变量和引用类型变量的差别
当使用final修饰基本类型变量时。不能对基本类型变量又一次赋值。因此基本类型变量不能被改变,但对于引用类型变量而言,它保存的不过一个引用,final只保证这个引用类型变量所引用的地址不会发生改变,即一直引用同一个对象,但这个对象全然能够发生改变。
6.可运行“宏替换”的final变量
对于一个final变量来说。无论它是类变量、实例变量,还是局部变量。仅仅要该变量满足三个条件,这个final变量就不再是一个变量,而是相当于一个直接量。
- 使用final修饰符修饰
- 在定义该final变量时指定了初始值
- 该初始值能够在编译时就被确定下来
final修饰符的一个重要用途就是定义“宏变量”。当定义final变量时就为该变量指定了初始值。并且该初始值能够在编译时就确定下来,那么这个final变量本质上就是一个“宏变量”。编译器会把程序中全部用到该变量的地方直接替换成该变量的值。
Java会使用常量池来管理以前用过的字符串直接量,比如运行String a = "java";语句之后,常量池中就会缓存一个字符串“java”;假设程序再次运行String b = "java";。系统就会让b直接指向常量池中的“java”,因此a == b 就会返回true。
7.内部类
非静态内部类的子类不一定是内部类。它能够是一个外部类。但非静态内部类的子类实例一样须要保留一个引用,该引用指向其父类所在外部类的对象。也就是说,假设有一个内部类子类的对象存在,则一定存在与之相应的外部类对象。
8.effectively final
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· Windows编程----内核对象竟然如此简单?