HashSet是无序的,不能存重复值,和hashMap本质上是一样的存储方式,出现重复内容会被覆盖掉。但是添加方式和list很像,都是add一个个添加,直接添加数值,没有键值对。
遍历的时候需要用到增强for循环,因为它没有下标,普通for循环没有get()
Set是HashSet的父类,所以这两个用哪个都行
public class SetTest {
@Test
public void test1(){
// set是无序的,不能存重复值,和hashMap本质上是一样的存储方式
HashSet<Integer> set = new HashSet<Integer>();
set.add(1);
set.add(2);
set.add(3);
set.add(4);
set.add(5);
// 增强for循环
for (Integer i : set){
System.out.println(i);
}
}
}
如果在使用list的时候想要删除重复内容,可以把list先放到set中,再把list清空,然后把set里的内容再放到list中就好了。先来个复杂版的:
public class ListTest {
@Test
public void testArrayList(){
List<Integer> list = new ArrayList();
list.add(1);
list.add(2);
list.add(3);
list.add(4);
list.add(5);
list.add(5);
list.add(2);
Set<Integer> set = new HashSet<>();
for (Integer integer : list){
set.add(integer);
}
list.clear();
for (Integer integer : set) {
list.add(integer);
}
for (Integer integer : list) {
System.out.println(integer);
}
}
}
现在外面来简洁一下:
public class ListTest {
@Test
public void testArrayList(){
List<Integer> list = new ArrayList();
list.add(1);
list.add(2);
list.add(3);
list.add(4);
list.add(5);
list.add(5);
list.add(2);
Set<Integer> set = new HashSet<>(list);
list = new ArrayList<>(set);
for (Integer integer : list) {
System.out.println(integer);
}
}
}
这样,多出来的5和2就被删掉了,没有了