Tak*_*shi 1 java linkedhashset
我有以下代码:
private static class Node {
public LinkedHashSet<String> s = new LinkedHashSet<String>();
public Node(String s) {
this.s.add(s);
}
}
public static void main(String[] args) {
LinkedHashSet<Node> set1 = new LinkedHashSet<Node>();
set1.add(new Node("foo"));
LinkedHashSet<Node> set2 = new LinkedHashSet<Node>(set1);
LinkedHashSet<String> modifyingSet = new LinkedHashSet<String>();
modifyingSet.add("modifying foo");
for(Node n : set2) {
n.s = new LinkedHashSet<String>(modifyingSet);
break;
}
if (compare(set1, set2)) {
System.out.println("Equal");
} else {
System.out.println("Not Equal");
}
return;
}
private static boolean compare(LinkedHashSet<Node> h1, LinkedHashSet<Node> h2) {
Iterator<Node> h1i = h1.iterator();
Iterator<Node> h2i = h2.iterator();
while (h1i.hasNext()) {
Node n1 = h1i.next();
Node n2 = h2i.next();
if (n1.s.size() != n2.s.size()) {
return false;
} else {
Iterator<String> it1 = n1.s.iterator();
Iterator<String> it2 = n2.s.iterator();
while (it1.hasNext()) {
String t1 = it1.next();
String t2 = it2.next();
if(!t1.equals(t2)) {
return false;
}
}
}
}
return true;
}
Run Code Online (Sandbox Code Playgroud)
当我修改set2时,set1也会被字符串"test"和"bogus"修改.因此,当我比较两个集合时,它们总是相等的(compare()比较每个集合中的字符串是否相等)
我的问题是:
根据我的理解,Java按值传递,但它似乎是通过引用传递的.任何人都可以帮我解决原因吗?我怎样才能将集合复制到临时集,然后修改集但不修改第一集?
我觉得我在这里错过了很简单的东西.
这里有很多问题和误解,所以这是一个清单.
a)您无法修改a的元素Set并期望它仍然有效.该对的JavadocSet更为具体:
注意:如果将可变对象用作set元素,则必须非常小心.如果在对象是集合中的元素的同时以影响等于比较的方式更改对象的值,则不指定集合的行为.这种禁令的一个特例是,不允许集合将自身作为一个要素包含在内.
总是假设"未指明的行为"转化为"它在你的脸上爆炸",或"它只会在星期二在Albequerque下雨时工作,所以它可能会工作一半时间并可能爆炸另一半."
b)您必须重写hashCode(),并equals(Object)在使用对象HashSet或者LinkedHashSet,如果你不想它们被相提并论==,它看起来像你可能不应该在这个应用程序.
c)Java 按值传递引用,这与传值和传递引用不同.特别是,修改对象将影响对同一对象的所有引用,但更改引用以引用其他对象将不会影响其他引用.
Set<Foo> set1 = new LinkedHashSet<Foo>();
Set<Foo> set2 = set1;
Set<Foo> set3 = set1;
set1.add(new Foo());
// set1, set2, and set3 each refer to the same Set, which now contains one Foo
set3 = new LinkedHashSet<Foo>();
// set1 and set2 still refer to the Set with one Foo;
// set3 now refers to a new empty Set
Run Code Online (Sandbox Code Playgroud)
d)复制一个LinkedHashSet,就这样做new LinkedHashSet<Foo>(setToCopy).
| 归档时间: |
|
| 查看次数: |
1131 次 |
| 最近记录: |