java拷贝对象
这是我个人的理解,加上以前看的一些帖子,有不对的地方,请高人指点。
1.作为java参数传递给一个函数的对象,除了很简单的如int或者boolean等简单的以外,传递的都是这个对象的引用。
当在接收函数中改变这个对象的时候,原来的对象即被改变。
2.在初始化一个对象的时候,有时候我们希望用一个已经存在的对象来给另外一个对象赋值,但是直接用“=”给另外一个
对象赋值的话,是错误的,这样会使两个不同的对象名字指向同一个对象。改变其中任何一个都会引起该对象的改变。
下面我们实验一下用一个对象给另外一个对象赋值:public class Student {
private int age;
private String name;
public Student(int age, String name) {
this.age = age;
this.name = name;
}
public void show() {
System.out.println(this.age + "" + this.name);
}
public void setAge()
{
this.age = 10;
}
}
public class test {
public static void main(String as[]) {
Student s = new Student(1, "name");
Student temp = s;
temp.setAge();
temp.show();
s.show();
}
}
上述代码运行结果如下:
10name
10name
结果表明,虽然是用student的对象s给temp赋值,但是temp和s是指向同一个对象的,temp指向的对象改变age的时候,s指向的对象的age也改变了。不是我们希望得到的。
在C++中,有深拷贝和浅拷贝两个概念,java中,我们用Cloneable接口来完全复制一个对象。
参考下面的代码:
public class BankAccount implements Cloneable {
private double balance;
public BankAccount(double ini) {
this.balance = ini;
}
protected Object clone() {
BankAccount bankAccount = null;
try {
bankAccount = (BankAccount) super.clone();
} catch (CloneNotSupportedException e) {
e.printStackTrace();
}
return bankAccount;
}
public void add(double give) {
this.balance += give;
}
public void redu(double give) {
this.balance -= give;
}
public double getBalance() {
return balance;
}
public void setBalance(double balance) {
this.balance = balance;
}
}
我们令BankAccount实现Cloneable接口,实现其父类(就是Object类)的clone函数。
看一下clone函数的doc:
Cr
相关文档:
与其它类不同,compareTo方法并不是Ojbect中的方法,它是Comparable接口中唯一的方法。通过实现Comparable接口,可以它能够自然排序。
排序,Arrays.sort(a); 就OK了。
书上提了一个巧妙的方法,用来消除重复的字符串。它用了一个Set集合来过滤重复的字段。
public class WordList {
&n ......
直接选择排序算法:从待排序的数据元素集合中选取最小的元素放到原始数据的第一个元素的位置上。然后不包括第一个元素的数据元素集合中找到最小的元素放到此集合中,依次类推,即可完成排序。
算法实现如下:
/**
* 直接选择排序
* @param a 用于排序的数组
* */
public void ......
java for foreach while循环的比较
关键字: java
在java中究竟是一般的for循环,还是for的增强型foreach,或是while的执行效率比较快呢,我用了一个简单的程序来分析3种循环
public static void main(String[] args) {
List<Integer> map = new ArrayList<Integer>();
for (int i = 0; i < ......
1、 继承和实现区别
Hashtable是基于陈旧的Dictionary类的,HashMap是Java 1.2引进的Map接口的一个实现。
2、 线程安全不同
HashTable的方法是同步的,HashMap是未同步,所以在多线程场合要手动同步HashMap。
3、 对null的处理不同
HashTable不允许null值(key和value都不可以),HashMap允许n ......