我尝试了getter方法(创建一个getter方法就是这个类并返回对象以便你可以在另一个类中使用它)但是当我运行它时只是一个空的ArrayList
在这个例子中,我让用户输入代码(1,2,3,...)和随机名称,然后将该值存储在ArrayList列表中,但是当我创建该类的实例并使用getList时()方法它返回一个空的ArrayList。 这是代码:
SubTestSite1
package testsite;
public class SubTestSite1 {
private int id;
private String name;
@Override
public String toString() {
return this.getId() + " " + this.getName()+" ";
}
public SubTestSite1() {
}
public SubTestSite1(int id, String name) {
this.id = id;
this.name = name;
}
public int getId() {
return id;
}
public String getName() {
return name;
}
public void setId(int id) {
this.id = id;
}
public void setName(String name) {
this.name = name;
}
}
SubTestSite2
package testsite;
import java.util.Scanner;
import java.util.ArrayList;
import java.util.Hashtable;
public class SubTestSite2 {
Hashtable hash = new Hashtable(100);
ArrayList list = new ArrayList(100);
Scanner sc = new Scanner(System.in);
public ArrayList getList() {
return list;
}
public void add() {
int id;
String name, choice = null, customer;
do {
System.out.print("enter id: ");
id = Integer.parseInt(sc.nextLine());
System.out.print("enter name: ");
name = sc.nextLine().trim().toUpperCase();
SubTestSite1 sts1 = new SubTestSite1(id, name);
list.add(sts1);
System.out.println("Continue? Y/N");
choice = sc.nextLine();
} while (choice.equalsIgnoreCase("y"));
System.out.print("Customer name: ");
customer = sc.nextLine();
hash.put(customer, list);
SubTestSite3 sts3 = new SubTestSite3();
sts3.displayOrder(this.hash, customer);
}
}
SubTestSite3
package testsite;
import java.util.Hashtable;
import java.util.ArrayList;
import java.util.Scanner;
public class SubTestSite3 {
public void displayOrder(Hashtable hash, String name) {
SubTestSite2 sts2 = new SubTestSite2();
System.out.println(sts2.getList());
}
}
主要
package testsite;
public class TestSite {
/**
* @param args the command line arguments
*/
public static void main(String[] args) {
SubTestSite2 sts2 = new SubTestSite2();
sts2.add();
}
}
不要介意Hashtable,我只是想玩弄它:P 谢谢!
答案 0 :(得分:0)
我没有看到您的main
方法,所以我猜您正在从SubTestSite2
创建一个main
对象,并在那里调用add()
。为清楚起见,我们称该对象为mainsts
。如果是这种情况,则将项目添加到主要列表中,然后创建新的SubTestSite2
对象sts2
,并尝试阅读sts2's
列表,而不是mainsts's
。由于您没有将ArrayList声明为静态,因此在这种情况下,每个对象,mainsts和sts2都有自己的列表,因此sts2的列表确实是空的,但是mainsts的列表不会是。
当您将ArrayList
声明为static
时,您将其变为类变量而不是实例变量。作为“静态”,使用该类的所有对象都将使用该变量。换句话说,这里的mainsts和sts2将共享相同的列表。如果你想要这个,我会说通过SubTestSite2.list