我的编程空间,编程开发者的网络收藏夹
学习永远不晚

java中的集合

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

java中的集合

1.集合概述

Java的集合框架是由很多接口、抽象类、具体类组成的,都位于java.util包中。

2.Collection接口

Collection 接口-定义了存取一组对象的方法,其子接口Set和List分别定义了存储方式。
Set 中的数据对象没有顺序且不可以重复。

List中的数据对象有顺序且可以重复。

3.List接口及其实现类

 List继承了Collection接口,有三个实现的类。
- ArrayList
数组列表,数据采用数组方式存储。
-LinkedList
链表
-Vector
数组列表,添加同步锁,线程安全的

public class VectorDemo {    public static void main(String[] args) {        Vector vector=new Vector();        vector.add("a");        vector.add("a");        vector.add("a");        vector.add("a");        vector.add("a");        System.out.println(vector);    }}

ArrayList实现了长度可变的数组,在内存中分配连续的空间
遍历元素和随机访问元素的效率比较高。

LinkedList采用链表存储方式插入、删除元素时效率比较高

ArrayList的常用方法
add(int index, E element)
get(int index)
indexOf(Object o)
lastIndexOf(Object o)
remove(int index)    删除并返回指定位置元素
removeRange (int fromIndex, int toIndex) 删除指定区间的元素(子类继承使用)
set(int index, E element)

 ArrayList arrayList=new ArrayList();        arrayList.add(100);        arrayList.add(1,10);        arrayList.add(20);        arrayList.add(20);        arrayList.add(20);        arrayList.add(20);        arrayList.add(20);        arrayList.add(20);        arrayList.add(20);        arrayList.add(20);        //arrayList.clear();        System.out.println(arrayList.contains(20));        System.out.println(arrayList.isEmpty());        System.out.println(arrayList.get(0));        System.out.println(arrayList.remove(1));//删除        System.out.println(arrayList.remove((Object)100));//删除某个值        Object [] array=arrayList.toArray();        System.out.println(Arrays.toString(array));//转数组        System.out.println(arrayList);

LinkedList的常用方法
add(int index,Object element)
addFirist(Object element)
addLast(Object element)
get(int index)
removeFirst()
removeLast()
remove(int index)
getFirst()
getLast()

LinkedList linklist=new LinkedList();        linklist.add("a");        linklist.add("a");        linklist.add("a");        linklist.add("a");        linklist.add("a");        //linklist.clear();        linklist.addFirst("e");        linklist.addLast("e");        //peek 检索不删除        //poll 检索并删除        System.out.println(linklist.getFirst());        System.out.println(linklist.pollLast());        System.out.println(linklist.removeFirst());        System.out.println(linklist.indexOf("a"));        System.out.println(linklist.set(0,"s"));        System.out.println(linklist.size());        System.out.println(linklist);

List接口集合迭代

● for循环遍历
● 增强for循环的遍历
● 迭代器遍历(Iterator)

ArrayList list = new ArrayList<>();        list.add("a");        list.add("a");        list.add("b");        list.add("c");        list.add("d");                     //迭代器iterator(        Iterator iterator = list.iterator();        while (iterator.hasNext()) {            String s = iterator.next();            if (s.equals("a")) {                iterator.remove();            }        }        System.out.println(list);

4.Set 接口

● Set接口继承了Collection接口。
Set中所存储的元素是不重复的,但是是无序的, Set中的元素是没有索引的
● Set接口有两个实现类


● HashSet
HashSet类中的元素不能重复,即彼此调用equals方法比较,都返回false。
底层数据结构是哈希表+链表
哈希表依赖于哈希值存储

public class HashSetDemo1 {    public static void main(String[] args) {        HashSet hashSet=new HashSet<>();          hashSet.add("a");          hashSet.add("白色");          int a="红色".hashCode();        System.out.println(a);          hashSet.add("黑色");        int a1="种地".hashCode();        System.out.println(a1);          hashSet.add("c");          hashSet.add("d");        System.out.println(hashSet);    }}
public class HashSetDemo {    public static void main(String[] args) {        HashSet hashSet=new HashSet<>();        Car car1= new Car("宝马1",101);        Car car5= new Car("宝马1",101);        Car car2= new Car("宝马2",102);        Car car3= new Car("宝马3",103);        Car car4= new Car("宝马4",104);        //在Car类中重写了hashcode方法,先对hash值进行比较,在对内容进行比较        hashSet.add(car1);        hashSet.add(car2);        hashSet.add(car3);        hashSet.add(car4);        hashSet.add(car5);        System.out.println(hashSet);    }


● TreeSet
可以给Set集合中的元素进行指定方式的排序。存储的对象必须实现Comparable接口。
TreeSet底层数据结构是二叉树(红黑树是一种自平衡的二叉树)。

public class TreeSetDemo {    public static void main(String[] args) {        TreeSet treeSet=new TreeSet<>();        Car car1= new Car("宝马1",101);        Car car5= new Car("宝马1",101);        Car car2= new Car("宝马2",102);        Car car3= new Car("宝马3",103);        Car car4= new Car("宝马4",104);        treeSet.add(car1);        treeSet.add(car3);        treeSet.add(car5);        treeSet.add(car2);        treeSet.add(car4);        System.out.println(treeSet);    }

5.Set接口集合的迭代

遍历方式
增强for循环
迭代器遍历

  ArrayList list = new ArrayList<>();        list.add("a");        list.add("b");        list.add("c");        list.add("d");       ListIterator listIterator=list.listIterator();       while(listIterator.hasNext()){           String s=listIterator.next();           System.out.println(s);       }      ListIterator listIterator1=list.listIterator(list.size());       while(listIterator.hasPrevious()){           String s=listIterator.previous();           System.out.println(s);       }

上文中用到的Car类中重写了一系列方法。

package com.ffyc.collection;public class Car  implements Comparable {    String name;    int num;    public int compareTo(Car o) {        return o.num-this.num;    }    public Car(String name, int num) {        this.name = name;        this.num = num;    }    @Override    public boolean equals(Object o) {        if (this == o) return true;        if (o == null || getClass() != o.getClass()) return false;        Car car = (Car) o;        if (num != car.num) return false;        return name != null ? name.equals(car.name) : car.name == null;    }    @Override    public int hashCode() {        int result = name != null ? name.hashCode() : 0;        result = 31 * result + num;        return result;    }    @Override    public String toString() {        return "Car{" +                "name='" + name + '\'' +                ", num=" + num +                '}';    }}

来源地址:https://blog.csdn.net/weixin_64189867/article/details/131133473

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

java中的集合

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Java中Map集合的双列集合怎么用

这篇文章给大家分享的是有关Java中Map集合的双列集合怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Map集合Map概述Map是一种依照键(key)存储元素的容器,键(key)很像下标,在List中下标是
2023-06-25

Java中集合的示例分析

小编给大家分享一下Java中集合的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!java集合java集合类存放于java.util包中,是一个用来存放对象
2023-06-20

java中集合有哪些

一、List集合:(有序,元素可以重复)1、ArrayList集合:1)底层数据结构是数组,查找快,增删慢。2)线程不安全,效率高2、Vector集合:1) 底层数据结构是数组,查询快,增删慢2)线程安全,效率低3、LinkedList集合:1) 底层数据结构
java中集合有哪些
2014-11-10

java中有哪些集合

java中集合类型主要有3种:set(集)、list(列表)和map(映射)。1、List(有序、可重复)List里存放的对象是有序的,同时也是可以重复的,List关注的是索引,拥有一系列和索引相关的方法,查询速度快。因为往list集合里插入或删除数据时,会伴
java中有哪些集合
2022-04-22

java集合的区别

集合的之间区别:List、Set、Map的区别 (推荐学习:java课程)List允许存重复对象,有序的,可以插入多个null元素Set不允许重复对象,无序的,只允许一个null元素Map是键值对存储数据,键是唯一的,可以有相同的值Array
java集合的区别
2021-01-31
2023-09-07

【Java】求两集合的交集、并集、差集

一、内置函数实现 1、removeAll方法:从list中删除指定集合中包含的所有元素。 2、retainAll方法:从list中删除指定集合中不包含的所有元素。 3、addAll方法:用来向Set集合添加另一个集合对象所包含的所有内容。
2023-08-18

Java中的set集合怎么应用

这篇文章主要讲解了“Java中的set集合怎么应用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java中的set集合怎么应用”吧!Set系类集合特点:无序:存取顺序不一致不重复:可以去除重
2023-07-02

java集合中list的示例分析

这篇文章主要为大家展示了“java集合中list的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“java集合中list的示例分析”这篇文章吧。1、List接口该接口定义的元素是有序的且可
2023-05-30

Java中什么是Map集合

小编给大家分享一下Java中什么是Map集合,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、什么是Map不同于List单列的线性结构,Java中的Map提供的是
2023-06-02

java中集合的区别是什么?

java中集合的区别是什么?在java中集合主要分为:List,Set,Map三种,其中List与Set是继承自Collection,而Map不是。List与Set的区别:List中的元素有存放顺序,并且可以存放重复元素,检索效率高,插入删除效率低,Set没有
java中集合的区别是什么?
2014-12-16

java 中集合的原理是什么

这期内容当中小编将会给大家带来有关java 中集合的原理是什么,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一、概述集合是一种长度可变,存储数据的数据结构多样,存储对象多样的一种数据容器。Java中集合可
2023-06-20

Java集合类的使用

这篇文章主要介绍“Java集合类的使用”,在日常操作中,相信很多人在Java集合类的使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java集合类的使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!集合
2023-06-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录