最近被前辈教育,要再系统的学习一下Java,遂重新拿起《Java编程思想》这本鸿篇巨著,每天记一点,看看自己能坚持到什么时候。
用引用操纵对象
一个有趣的比喻
引用-> 遥控器
对象-> 电视机
遥控器可以没有电视独立存在,但不指定电视就无法使用甚至报错
new的意思就是“给我一个新的对象”
存储数据的5个位置
1)寄存器:最快的存储区,在CPU内部,无法控制
2)堆栈:位于通用RAM中,创建程序是,Java系统必须知道存储在堆栈中的所有项的生命周期,以便上下移动堆栈指针,这影响了程序的灵活性。所以Java对象不在其中
3)堆:一种通用内存池(也在RAM中),用于存放Java对象,运行时分配,导致回收时间长
4)常量存储:例子,字符串池。
==和equals之间的破事儿:==判断的是地址,equals判断的是实际值。一般字符串比较用equals。
字符串常量是保存在常量池里,而字符串对象保存在堆中,当两个常量相加时,相当于是又指向了一个新的字符串常量池地址。而两个字符串对象相加时,则意味着new了一个StringBuilder后appen的一个新对象。
String str1 = "string";
String str2 = "str" + "ing";
String str3 = new String("string");
String ste41 = "str";
String str42 = "ing";
String str4 = ste41 + str42;
System.out.println("str1==str2:" + (str1 == str2)); // true
System.out.println("str1==str3:" + (str1 == str3)); // false
System.out.println("str1.equals(str3):" + str1.equals(str3)); // true
System.out.println("str1==str4:" + (str1 == str4)); // false
在理解这个问题时,学了个新方法,在out路径下,用javap -c xxx.class可以看到JVM的机器码,对于两个字符串对象相加的场景就比较好理解了。
24: new #7 // class java/lang/StringBuilder
27: dup
28: invokespecial #8 // Method java/lang/StringBuilder."<init>":()V
31: aload 4
33: invokevirtual #9 // Method java/lang/StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
36: aload 5
38: invokevirtual #9 // Method java/lang/StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
41: invokevirtual #10 // Method java/lang/StringBuilder.toString:()Ljava/lang/String;
5)非RAM存储:
a.流对象
b.持久化对象 JDBC,hibernate
一些类型不是对象
1)基本类型8+void
2)高精度数字是没有基本类型的
数组
存在下标保护,损失一定性能
类的字段和方法
对于成员变量,有基本默认值,对于方法中的局部变量没有默认值,所以需要初始化一下
int x = a.f() 发送消息f()给对象a,将对象a的回应告诉x
static关键字
当声明一个事物是static时,就意味着这个域或方法不会与包含它的那个类的任何对象实例关联在一起
JDK文档&Java源码
写代码不会用了就看看JDK文档,有空了就看看Java源码