“==”和“equals”的用法
在Java中,boolean、byte、short、int、long、char、float、double这八种是基本数据类型,其余的都是引用类型。
“==”是比较两个变量的值是否相等,“equals”是比较两个对象变量所代表的对象的内容是否相等,它是Object类中的一个方法
当我们声明一个引用类型变量时,系统只为该变量分配了引用空间(栈空间),并未创建一个具体的对象;当用new为对象分配空间(堆空间)后,将对象的引用(也即对象所在的地址)赋值给引用它的变量
当用new创建一个对象str1,再将str1的值赋值给str2,此时是str1和str2指向同一个对象
String和StringBuffer
针对String的“+”和“+=”,是Java中唯一被重载的操作符;在Java中,不允许程序员重载操作符,String类型可以和基本数据类型或引用数据类型进行这两种操作,当+的左右有一个String类型,所有其他类型将自动转换为字符串类型
String类对象一个常量对象(注意理解:它的对象一旦赋值是不能改变的)。
如:String str=“abc”;
str=“def”;
之后str中保存了字符串”def”的一个引用,而”abc”所占用的内存将变成垃圾内存
在处理大量字符串的程序中,我们通常用StringBuffer来替代String,它们是一样的,但是StringBuffer可以被修改
一个例子:
String str1=new String("abc");
int i=3;
float f= 1.5f;
StringBuffer sb=new StringBuffer();
sb.append(str1).append(i).append(f);//StringBuffer类中的一个方法,追加字符串表示到序列
System.out.println(sb.toString()); /*toString()方法原来是Object类中的方法,被StringBuffer类重写,返回此序列中数据的字符串表示形式*/
System.out.println(sb); //可以直接写sb对象,系统将直接调用toString()方法
注意:索引从0开始,包含左索引,不包含右索引
关于StringBuffer类的其他方法参照API文档
数组
Java中每一个数组都有一个属性length,它用来记录数组中元素的个数
创建了一个数组num后,用num=null;给它赋值,相当于撤销了num变量对数组对象的引用,数组对象此时变成了垃圾内存。这种用null赋值的方法也同样适用于其他引用类型
对象数组的内存分配:Student类型为类类型
1.Student[] students; 在栈内存中给students变量分配一片空间,null
2.students=new Student[3]; 在堆内存中创建一个对象数组(3个元素,null),将数组的首地址赋值给students变量
3.students[0]=new Student(“lisi”,18); 在堆内存中创建一个Student对象并把地址赋值给对象数组的第一个元素
函数的调用
main方法是java虚拟机调用,所以必须为public,因为不产生对象,所以声明为static,无返回值,所以是void。 参数是一个String对象数组,用来保存命令行参数
在Java中,传参时,都是以传值的方式进行
对于基本数据类型,传递的是数据的拷贝
对于引用类型,传递的是引用的拷贝
由此引出的一些问题值得注意。Test.java Test2.java
直接打印一个对象的时候,调用Object类中的toString()方法,返回的是对该对象的字符串表示“类@地址”,建议子类重写该方法
对象的克隆(clone)
为了获取对象的一份拷贝,我们可以利用Object类的clone()方法
步骤:
在派生类中覆盖基类的clone()方法,并声明为public
在派生类的clone()方法中,调用super.clone()
在派生类中实现Cloneable接口(它是一个没有任何抽象方法的接口,实现它只是为了说明”我可以被克隆了”)
为什么我们在派生类中覆盖Object的clone()方法时,一定要调用super.clone()呢?在运行时刻,Object中的clone()识别出你要复制的是哪一个对象,然后为此对象分配空间,并进行对象的复制,将原始对象的内容一一复制到新对象的存储空间中