java中怎么往集合类set里添加数据??

java中怎么往集合类set里添加数据??,第1张

两种向Set中添加元素的方法,第一种是使用add()方法,每次添加一个元素到set中,当集合中不存在相同元素时将添加到集合中,并返回true,当集合中存在元素时,返回false。代码如下:

Set<String>sets = new HashSet<>()

sets.add("String")

System.out.println(sets.add("Tree"))

System.out.println(sets.add("String"))

List<String>lists = new LinkedList<>()

lists.add("test")

lists.add("test")

lists.add("one")

System.out.println(sets.addAll(lists))

还有一个是向集合中批量添加元素的方法addAll(),这个方法的入参是Colletion。上述代码执行结果如下:

扩展知识

Set集合可以知道某物是否已近存在于集合中,不会存储重复的元素,注重独一无二的性质,用于存储无序(存入和取出的顺序不一定相同)元素,值不能重复。可以很好地作为排重时使用的数据结构,但要注意集合内部数据一般情况没有顺序。常用的set有HashSet和TreeSet。

TreeSet是JAVA中集合的一种,TreeSet 是一个有序的集合,它的作用是提供有序的Set集合。它继承于AbstractSet抽象类,实现了NavigableSet<E>,Cloneable,java.io.Serializable接口。一种基于TreeMap的NavigableSet实现,支持2种排序方式:自然排序 或者 根据创建TreeSet 时提供的 Comparator 进行排序。

首先你应该知道Set的继承体系吧,它和List都是继承于接口Collection的,它们底层有的用数组实现,有的用链表来实现。

对于Set来说,它还有TreeSet和HashSet两个子类。首先,说Set是没有顺序的是不准确的。

1,对于HashSet来说,它是按照你存入对象的hashcode的值来排序的,几乎没有规律,所以我们可以认为它是无序的。

2,对于TreeSet来说,它有自然排序和定制排序两种排序方式,通过你传入的对象实现Comparable接口和Comparator接口来实现,要是详细讲解的话知识点还是比较多的,你可以自己去查资料。

Set说完了,那么我们就来说说这个接口所提供的关于删除的方法。

1,clear()

移除此 set 中的所有元素(可选 *** 作)。,

2,remove(Object o)

如果 set 中存在指定的元素,则将其移除(可选 *** 作)。

3,removeAll(Collection<?>c) 移除 set 中那些包含在指定 collection 中的元素(可选 *** 作)。 ,

4,retainAll(Collection<?>c) 仅保留 set 中那些包含在指定 collection 中的元素(可选 *** 作)。

在具体的你就 自己去看Api文档吧

1、定义一个Set的对象

Set set=new HashSet()//new 一个hashset2、往set中添加字符串数据数据

set.add("内容")//往set里添加一个字符串"内容"Set是最简单的一种集合,没有重复对象。Set接口主要实现了两个实现类:

HashSet

:

HashSet类按照哈希算法来存取集合中的对象,存取速度比较快

TreeSet

:

TreeSet类实现了SortedSet接口,能够对集合中的对象进行排序。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11662008.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-17
下一篇 2023-05-17

发表评论

登录后才能评论

评论列表(0条)

保存