当前位置:首页 » 编程语言 » javamaplist

javamaplist

发布时间: 2023-03-13 09:55:01

java List和Map的问题

确实如题主所说。具体原因应该是数据结构上的问题。查阅HashMap底层原理的相关资料后,大家都说地天花乱坠我也看不懂。看下来我认为吧,HashMap的每一个key,它绑定了它对应value的地址,只要key保持不变,那么指针位置也就不会改变。地址不变,在任意地方将value的值进行改变,那么所有get(key)出来的值就跟着改变了。

利用HashMap的这个特性,可以在类和类之间设计变量池,将多个类之间共享的变量放到同一个HashMap中,类与类之间的方法调用参数使用这个变量池,这样只要变量池里某个变量的值在一个类中发生了改变,其他类再get这个变量时也能拿到改变后的值了。

㈡ java中list和map的区别

List中的对象按照索引位置排序,可以有重复对象,允许按照对象在集合中的索引位置检索对象,如通过list.get(i)方式来获得List集合中的元素。
Map中的每一个元素包含一个键对象和值对象,它们成对出现。键对象不能重复,值对象可以重复。

㈢ Java集合中List和 Map区别

一个是存储单列数据的集合,,另外一个是存储键和值这样的双列数的集合,List中存储的数据是有顺序的,并且允许重复。。。Map中存储的数据是没有顺序的,其键是不能重复的,它的值是可以有重复的。。。

List继承Collection接口,,Map不继承Collection接口。

㈣ java list 与map有什么区别

List:是存储单列数据的集合,存储的数据是有序并且是可以重复的


Map:存储双列数据的集合,通过键值对存储数据,存储 的数据是无序的,Key值不能重复,value值可以重复key和value是一一对应的

Collection接口

Collection是Java中最基本的集合接口。它描述了一组有关集合操作的方法。

  • int Size(); //集合大小

  • boolean isEmpty(); //是否为空

  • boolean contains(Object o); //是否包含某个对象

  • Iterator<E> iterator(); //返回一个迭代对象,用来遍历集合中的元素

  • Object[] toArray(); //将集合中的元素以数组形式然后返回

  • <T> T[] toArray(T[] a); //上一个方法的泛型形式

  • boolean add(E e); //将对象e添加进集合,添加成功则返回true

  • boolean remove(Object o); //移除某个元素

  • boolean containsAll(Collection<?> c); //传入一个集合c,如果c中的元素都存在,则返回true

  • boolean addAll(Collection<? extends E> c); //将集合c中的元素全部添加进本集合

  • boolean removeAll(Collection<?> c); //本集合减去c集合中的元素

  • boolean retainAll(Collection<?> c); //取本集合和c集合的交集

  • void clear(); //清空集合

  • boolean equals(Object o); //判断相等

  • int hashCode(); //获取集合当前的hash值

  • Set接口

    Set接口直接继承自Collection接口,并且方法接口上也一模一样。Set对添加的元素有一些要求,其不允许出现重复的元素,并且元素之间没有次序。这相当于一个不允许重复的离散的集合。因此,添加进Set的元素类型需要定义equals方法。若是使用自定义的类,则应该重写equals方法来确保实现自己需要的功能。

    Set接口主要实现了两个类:HashSet,TreeSet。

    HashSet是按照哈希来存取元素的,因此速度较快。HashSet继承自抽象类AbstractSet,然后实现了Set、Cloneable、Serializable接口。
    TreeSet也是继承自AbstractSet,不过不同的是其实现的是NavigableSet接口。而NavigableSet继承自SortedSet。SortedSet是一个有序的集合。其添加的元素必须实现了Comparable接口,因为其在添加一个元素的时候需要进行排序。NavigableSet则提供了更多的有关元素次序的方法。


  • LinkedHashSet也是Set的一个实现。和HashSet类似,只不过内部用链表来维护,按照元素插入次序来保存。

    List接口

    List接口也是继承自Collection。与Set不同的是,List可以存储重复的元素。主要有两种实现:ArrayList和LinkedList。
    ArrayList没有什么好说的,就像传统的数组一样,有着很快的随机存取速度,但是插入删除的速度就很慢。
    LinkedList则与ArrayList恰恰相反,因为用链表来保存数据,所以插入删除元素的速度很快,但是访问数据的速度就不如ArrayList了。

    Map接口

    Map(映射)是一个存储键值对的容器接口。每一个元素包含一个key对象和value对象,且元素不允许重复。
    Map接口的实现有以下几个:
    HashMap是最常用的一个实现。HashMap使用hash映射来存取数据,这个速度是相当快,是O(1)的速度。其容量capacity,和负载因子load factor可以在一开始设定。当元素个数达到capacity*load factor的时候,就会进行扩容。
    LinkedHashMap和HashMap类似,只不过内部用链表来维护次序。因此遍历时候的顺序是其插入顺序。
    TreeMap是基于红黑树的Map,插入的数据被有次序保存,并且有很高的效率。因此在遍历输出的时候可以得到排序的数据。但是这要求插入的数据实现了comparable接口。

    总结

  • Collection、Set、List和Map都是接口,不能被实例化。

  • Set和List都继承自Collection,而Map则和Collection没什么关系。

  • Set和List的区别在于Set不能重复,而List可以重复。

  • Map和Set与List的区别在于,Map是存取键值对,而另外两个则是保存一个元素。

希望对您有所帮助!~

㈤ java的List<Map>用法

//存放所有学生信息
List<Map<String,Object>> listStudentInfo=new ArrayList<Map<String,Object>>();
//定义学生1的一些属性

Map<String,Object> stu1=new HashMap<String, Object>();
stu1.put("sId", 111);//学号
stu1.put("sName", "张三");//姓名
stu1.put("sSex", "男");//性别
listStudentInfo.add(stu1);

//定义学生2的一些属性
Map<String,Object> stu2=new HashMap<String, Object>();
stu2.put("sId", 112);//学号
stu2.put("sName", "李四");//姓名
stu2.put("sSex", "女");//性别
listStudentInfo.add(stu2);
//得到所有学生信息
for( Map<String,Object> stu:listStudentInfo)
{
System.out.println("学号:"+stu.get("sId")+" 姓名:"+stu.get("sName")+" 性别:"+stu.get("sSex"));
}

热点内容
动态规划01背包算法 发布:2024-11-05 22:17:40 浏览:849
nasm编译器如何安装 发布:2024-11-05 22:01:13 浏览:180
登录密码在微信的哪里 发布:2024-11-05 22:00:29 浏览:739
c防止反编译工具 发布:2024-11-05 21:56:14 浏览:247
安卓虚拟机怎么用 发布:2024-11-05 21:52:48 浏览:344
php时间搜索 发布:2024-11-05 20:58:36 浏览:478
燕山大学编译原理期末考试题 发布:2024-11-05 20:13:54 浏览:527
华为电脑出现临时服务器 发布:2024-11-05 20:05:08 浏览:408
斗战神免费挖矿脚本 发布:2024-11-05 19:53:25 浏览:665
网吧服务器分别是什么 发布:2024-11-05 19:45:32 浏览:392