一段代码搞懂关于Java中List、Set集合及Map的使用
java中list、set集合及map的使用代码如下所示:
package tingjizifu; import java.util.*; public class tongji { /* * 使用scanner从控制台读取一个字符串,统计字符串中每个字符出现的次数,要求使用学习过的知识完成以上要求 * 实现思路根据set、list、map集合的特性完成。 */ public static void main(string[] args) { // 输入字符串 scanner input = new scanner(system.in); string shuru = input.next(); // 把字符串字符装入list集合 list<string> list = new arraylist<string>(); for (int i = 0; i < shuru.length(); i++) { list.add(string.valueof(shuru.charat(i))); } // 把字符串字符装入set集合 set<string> set = new hashset<string>(); for (int i = 0; i < shuru.length(); i++) { set.add(string.valueof(shuru.charat(i))); } // 用set中的字符与list中的字符进行比较,相同就加1进行计数, // 然后把set集合中的字符作为键(key),统计的数作为值(value),最后打印出map中的数据 map<string, integer> map = new hashmap<string, integer>(); for (string str : set) { int sum = 0; // system.out.println(str); for (int i = 0; i < list.size(); i++) { if (list.get(i).equals(str)) { sum++; } } map.put(str, sum); } set<string> ss = map.keyset(); for (string str : ss) { system.out.println(str + "出现次数为" + map.get(str) + "次"); } input.close(); } }
下面看下set map list的区别
都是集合接口
set --其中的值不允许重复,无序的数据结构
list --其中的值允许重复,因为其为有序的数据结构
map--成对的数据结构,健值必须具有唯一性(键不能同,否则值替换)
list 按对象进入的顺序保存对象,不做排序或编辑操作。
set对每个对象只接受一次,并使用自己内部的排序方法(通常,你只关心某个元素是否属于set,而不关心它的顺序--否则应该使用list)。
map同样对每个元素保存一份,但这是基于"键"的,map也有内置的排序,因而不关心元素添加的顺序。如果添加元素的顺序对你很重要,应该使用 linkedhashset或者linkedhashmap.
collection 是对象集合, collection 有两个子接口 list 和 set
list 可以通过下标 (1,2..) 来取得值,值可以重复
而 set 只能通过游标来取值,并且值是不能重复的
arraylist , vector , linkedlist 是 list 的实现类
arraylist 是线程不安全的, vector 是线程安全的,这两个类底层都是由数组实现的
linkedlist 是线程不安全的,底层是由链表实现的
map 是键值对集合
hashtable 和 hashmap 是 map 的实现类
hashtable 是线程安全的,不能存储 null 值
hashmap 不是线程安全的,可以存储 null 值
以上所述是小编给大家介绍的关于java中list、set集合及map的使用知识,希望对大家有所帮助
上一篇: Java输入输出流复制文件所用时间对比