1,声明一个List集合,并未其填充数据
List li = new ArrayList<>();
li.add(1);
li.add(2);li.add(3);li.add(4);li.add(5);li.add(1);
方法一
//判断集合里面元素是否重复
//JDK 1.8新特性,通过stream来判断
//todo 02
Integer priCount = li.size(); //集合的长度
Long nextCount = li.stream().distinct().count(); //经过处理之后的集合长度
System.out.println("JDK1.8新特性:==="+(priCount == nextCount.intValue()));
很显然,返回结果为true, 则元素不重复,返回结果为false,则元素重复
方法二 :利用集合特性,set集合元素不重复特点,将List转成set集合
//todo 01 集合转换为Set
Set<Integer> set = new HashSet<>(li);
System.out.println("======集合之前的长度为:"+li.size());
System.out.println("======集合之后的长度为:"+set.size());
System.out.println((li.size() == set.size()));
返回结果要么为true,要么为false,true代表集合并无重复元素,false代表元素重复
方法三 :最蠢的方法也是最笨的,相信所有人都不会用到,就是遍历集合,移除相同的元素,然后集合前后对比,看看集合元素个数是否相等
for ( int i = 0 ; i < list.size()-1 ; i ++ ){
for ( int j = list.size()-1 ; j> i; j--){
if (list.get(j).equals(list.get(i))){
list.remove(j);
}
}
}