集合体系java

Collection:单列集合:每个元素只包含一个值

Collection集合存储的是地址

Collection的三种遍历方法如下

//迭代器是用来遍历集合的专用方式(数组没有迭代器),在java中迭代器的代表是Iterator
//boolean hasNext():询问当前位置是否有元素存在
//E next():获取当前位置的元素,并同时将迭代器指向下一个元素处
public class CollectionTest3 {
    public static void main(String[] args) {
        Collection<String> c = new ArrayList<>();
        c.add("java1");
        c.add("java2");
        c.add("java3");


        //从集合对象获取迭代器对象
        Iterator<String> iterator = c.iterator();
        while(iterator.hasNext()){
            System.out.println(iterator.next());
        }

        //增强For循环:可以遍历数组或集合,本质就是迭代器遍历集合的简便写法
        /*
        for(元素的数据类型 变量名:数组或者集合)
         */
        for(String s:c){
            System.out.println(s);
        }

        //使用Lambda表达式遍历
        c.forEach(new Consumer<String>() {
            @Override
            public void accept(String s) {
                System.out.println(s);
            }
        });

        c.forEach((String s) -> {
                System.out.println(s);
        });

        c.forEach( s -> {
            System.out.println(s);
        });

        c.forEach( s -> System.out.println(s));

        c.forEach(System.out::println);
    }
}

1. List系列集合:添加的元素是有序,可重复,有索引。

List集合存储的是内容

四种遍历方式如下

public class ListTest1 {
    public static void main(String[] args) {
        List<String> list = new ArrayList<>();
        list.add("java1");
        list.add("java2");
        list.add("java2");
        //        System.out.println(list);

        //for循环遍历
        for (int i = 0; i < list.size(); i++) {
            System.out.println(list.get(i));
        }

        //迭代器遍历
        Iterator<String> iterator = list.iterator();
        while(iterator.hasNext()){
            System.out.println(iterator.next());
        }

        //增强for循环
        for (String s : list) {
            System.out.println(s);
        }

        //Lambda表达式遍历
        list.forEach( System.out::println);

    }
}
a. ArrayList:有序,可重复,有索引( 基于数组实现 )

查询快,增删慢

  • 查询速度快(是根据索引查询数据快)
  • 删除效率低:可能需要把后边很多数据进行前移
  • 添加数据效率极低:可能需要把后边很多数据后移,再添加元素;或者也可能进行数组的扩容

底层原理:(1)利用无参构造器创建的集合,会在底层创建一个默认长度为0的数组

(2)添加第一个元素时,底层会创建一个新的长度为10的数组

(3)存满时,会扩容1.5倍

(4)如果一次添加多个元素,1.5倍还放不下,则创建数组的长度以实际为准

b. LinkedList:有序,可重复,有索引(基于双向链表实现)

适合用作 队列,栈

  • 查询慢,增删相对较快,但对首尾进行增删改查的速度是极快的

(API中有 在头部增加删除元素,在尾部增加删除元素 方法)

2. Set系列集合:添加的元素是无序,不重复,无索引.

a. HashSet : 无序,不重复,无索引(基于哈希表实现,底层基于Map实现的,只是只要键数据,不要值数据)

增删改查性能都较好

哈希值:java中每个对象都有一个哈希值,是一个int类型的数据

哈希表:数组+链表+红黑树

底层原理:(1)创建一个默认长度16的数组,默认加载因子为0.75,数组名为table

(2)使用元素的哈希值对数组长度求余计算出应存入的位置

(3)判断当前位置是否为null,如果是null直接存入

(4)如果不为null,表示有元素,则调用equals方法比较

相等,则不存;不相等,则存入数组

(数组占满后,扩容16*0.75=12个)

JDK8之前,新元素存入数组,占老元素位置,老元素挂在下面(链表)

JDK8之后,新元素挂在老元素下面(链表),当链表长度超过8,且数组长度
>=64时,自动将链表转成红黑树

如果Set集合认为两个内容一样的对象是重复的,必须重写对象的HashCode()方法和equals()方法

b. LinkedHashSet : 有序,不重复,无索引(基于哈希表实现,底层基于LinkedHashMap实现)

每个元素都额外多了一个双链表的机制记录它前后元素的位置

c. TreeSet : 按照大小默认升序排序,不重复,无索引(基于红黑树实现)

存储自定义的对象时,必须制定规则排序,支持如下两种方法(见 对象排序的两种方法)

Map:双列集合,每个元素包含两个值(键值对)

键不可以重复,值可以重复

在做购物车时,商品与购买数量是一对数据等等

把Map集合变成Set集合(把一个键值对看成一个元素)

Set<Map.Entry<String, Integer>> entries = map.entrySet();

map集合三种遍历方式如下

import java.util.HashMap;
import java.util.Map;
import java.util.Set;
import java.util.function.BiConsumer;

public class MapTest1 {
    public static void main(String[] args) {
        Map<String,Integer> map = new HashMap<>();
        map.put("张三",20);
        map.put("张三",21);
        map.put("李四",19);
        map.put("王五",20);

        System.out.println(map);


        //键找值
        //获取map集合的全部键
        Set<String> keys = map.keySet();
        System.out.println(keys);
        //遍历全部的键,获得值
        for (String key : keys) {
            Integer i = map.get(key);
            System.out.println(key+"==>"+i);
        }

        //把键值对看成一个整体进行遍历
        //1.调用map集合提供的entrySet方法,把map集合转换成键值对类型的set集合
        Set<Map.Entry<String, Integer>> entries = map.entrySet();
        //entires = {(张三=21),(李四=19),(王五=20)}
        for (Map.Entry<String, Integer> entry:entries) {
            String key = entry.getKey();
            Integer value = entry.getValue();
            System.out.println(key+"==>"+value);
        }

        //lambda表达式遍历
        map.forEach((k,v) -> {
            System.out.println(k+"==>"+v);
        });
        //即
        map.forEach(new BiConsumer<String, Integer>() {
            @Override
            public void accept(String k, Integer i) {
                System.out.println(k+"==>"+i);
            }
        });

    }
}

1.HashMap(由键决定特点):无序,不重复,无索引(基于哈希表实现)

键相同时,后边的内容会覆盖前边的

public class MapTest1 {
    public static void main(String[] args) {
        Map<String,Integer> map = new HashMap<>();
        map.put("手表",2);
        map.put("手表",15);
        map.put("手机",5);
        map.put(null,null);
        System.out.println(map);
        //{null=null, 手表=15, 手机=5}
    }
}
  • HashMap集合是一种增删改查数据,性能都较好的集合
  • 但是他是无序的,不能重复,没有索引支持的(由键决定的特点)
  • HashMap的键依赖HashCode方法和equals方法保证键的唯一
  • 如果存储的是自定义类型的对象,可以通过重写通过 HashCode方法和equals方法,这样可以保证多

个对象内容一样时,HashMap集合就能认为是重复的

a.LinkedHashMap:有序,不重复,无索引

底层数据结构依然是基于哈希表实现的,只是每个键值对元素又额外的多了一个双链表的机制记录元素顺序(保证有序)

2.TreeMap:按照大小默认升序排序,不重复,无索引

集合的并发修改异常

  • 使用迭代器遍历时,又同时在删除集合中的数据,程序就会出现并发修改异常
  • 使用 增强for循环,lambda表达式 遍历集合并删除数据,没有办法解决bug

解决办法

  List<String> list = new ArrayList<>();
        list.add("java1");
        list.add("java2");
        list.add("java2");
        list.add("java21");
        list.add("java3");
        list.add("java11");
        //迭代器遍历
        Iterator<String> iterator = list.iterator();
        while(iterator.hasNext()){
            String name = iterator.next();
            if (name.contains("1")){
//                list.remove(name);//会出现并发错误,会漏删
                iterator.remove();//删除迭代器当前遍历到的数据,每删除一个数据后,相当于在底层做了i--
            }
        }

        //for循环遍历
        for (int i = 0; i < list.size(); i++) {
            String name = list.get(i);
            if (name.contains("1")){
                list.remove(name);
                i--;
            }
        }

可变参数

  • 就是一种特殊形参,定义在方法,构造器的形参列表里,格式是:数据类型,参数名称
特点和好处
  • 好处:可以不传数据给他;可以同时传一个或者同时传多个数据给他;也可以传一个数组给她
  • 好处:常常用来灵活的接收数据
注意:
  • 一个形参列表中,只能有一个可变参数
  • 可变参数必须放到形参列表的最后边
public class ParamTest {
    public static void main(String[] args) {
        test();
        test(1);
        test(1,2);
        test(new int[]{1,2,3});
    }

    //一个形参列表中,只能有一个可变参数
    //可变参数必须放到形参列表的最后边
    public static void test(int...nums){
        //可变参数在方法内部,本质就是一个数组
        System.out.println(nums.length);
        System.out.println(Arrays.toString(nums));
        System.out.println("----------------");

    }
}

Collections是一个用来操作集合的工具类

集合的嵌套:集合中的元素又是另外一个集合

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/544800.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

10万字208道Java经典面试题总结(2024修订版)- SSM篇

&#x1f345; 作者简介&#xff1a;哪吒&#xff0c;CSDN2021博客之星亚军&#x1f3c6;、新星计划导师✌、博客专家&#x1f4aa; &#x1f345; 哪吒多年工作总结&#xff1a;Java学习路线总结&#xff0c;搬砖工逆袭Java架构师 &#x1f345; 技术交流&#xff1a;定期更新…

(三)C++自制植物大战僵尸游戏项目结构说明

植物大战僵尸游戏开发教程专栏地址http://t.csdnimg.cn/ErelL 一、项目结构 打开项目后&#xff0c;在解决方案管理器中有五个项目&#xff0c;分别是libbox2d、libcocos2d、librecast、libSpine、PlantsVsZombies五个项目&#xff0c;除PlantsVsZombies外&#xff0c;其他四个…

map与set

set使用 set在我们就是我们前面学习的k模型&#xff0c;它可以用来比对数据&#xff0c;增删查的时间复杂度都是O&#xff08;logn&#xff09;效率非常高&#xff0c;由于它底层的原因&#xff0c;它也可以实现排序&#xff0c;通过中序遍历可以输出我们的有序的数据&#xff…

#新版Onenet云平台使用(ESP8266 AT指令上报数据以及公网MQTT服务器连接测试)

1.上云方式&#xff1a;MQTT 参考&#xff1a; 新版ONENET物联网开放平台ATMQTT指令连接_at指令连接onenet的mqtt-CSDN博客https://blog.csdn.net/lilbye/article/details/131770196 ESP8266-01s入门&#xff1a;AT指令讲解、上云与MQTT通信教程-物联沃-IOTWORD物联网https:…

软考 系统架构设计师系列知识点之大数据设计理论与实践(5)

接前一篇文章&#xff1a;软考 系统架构设计师系列知识点之大数据设计理论与实践&#xff08;4&#xff09; 所属章节&#xff1a; 第19章. 大数据架构设计理论与实践 第3节 Lambda架构 19.3.1 Lambda架构对大数据处理系统的理解 Lambda架构由Storm的作者Nathan Marz提出&…

SpringCloud实用篇(四)——Nacos

Nacos nacos官方网站&#xff1a;https://nacos.io/ nacos是阿里巴巴的产品&#xff0c;现在是springcloud的一个组件&#xff0c;相比于eureka的功能更加丰富&#xff0c;在国内备受欢迎 nacos的安装 下载地址&#xff1a;https://github.com/alibaba/nacos/releases/ 启动…

vscode远程连接centos

文章目录 vacode连接linux1. 安装插件2. 查看配置3. 打开ssh4. 远程连接 vacode连接linux 1. 安装插件 在扩展栏搜索remote &#xff0c;找到Remote Development插件&#xff0c;进行安装&#xff1a; 2. 查看配置 打开自己的linux终端&#xff0c;输入ifconfig&#xff0c;…

BackTrader 中文文档(九)

原文&#xff1a;www.backtrader.com/ 期货和现货补偿 原文&#xff1a;www.backtrader.com/docu/order-creation-execution/futurespot/future-vs-spot/ 发布1.9.32.116添加了对在社区中提出的一个有趣用例的支持。 通过未来开始交易&#xff0c;其中包括实物交割 让指标告诉…

怎么做预约小程序_探索我们的全新预约小程序

在繁忙的现代生活中&#xff0c;无论是想预约一次美容护理&#xff0c;还是预定一家心仪的餐厅&#xff0c;亦或是安排一次专业的咨询服务&#xff0c;我们都希望能够在最短的时间内完成这些操作&#xff0c;节省时间和精力。如今&#xff0c;一款全新的预约小程序应运而生&…

SSH安全设置

今天发现自己的公有云服务器被攻击了 然后查看了登录日志&#xff0c;如上图 ls -sh /var/log/secure vim /var/log/secure然后增加了安全相关的设置 具体可以从以下方面增加安全性&#xff1a; 修改默认SSH端口公有云修改安全组策略及防火墙端口设置登录失败次数锁定用户及限…

亚马逊CloudFront使用体验

前言 首先在体验CloudFront之前&#xff0c;先介绍一下什么是CDN&#xff0c;以及CDN的基本原理。 CDN是Content Delivery Network&#xff08;内容分发网络&#xff09;的缩写&#xff0c;是一种利用分布式节点技术&#xff0c;在全球部署服务器&#xff0c;即时地将网站、应…

LSTM 循环神经网络原理深度解读与网络结构精细剖析

长短期记忆网络&#xff08;Long Short-Term Memory, LSTM&#xff09;是一种特殊的循环神经网络&#xff08;Recurrent Neural Network, RNN&#xff09;&#xff0c;设计用于解决长期依赖问题&#xff0c;特别是在处理时间序列数据时。 循环神经网络&#xff08;RNN&#xf…

每日一VUE——组件的生命周期

文章目录 VUE组件的生命周期生命周期钩子函数实例创建Teleport VUE组件的生命周期 组件生命周期 组件从创建到挂载、更新、到销毁的一系列过程被称为组件的生命周期。 生命周期函数 在组件的各个生命周期节点执行的函数&#xff0c;为生命周期钩子函数。 生命周期钩子函数…

RT-thread信号量与互斥量

1,信号量 信号量是一种轻型的用于解决线程间同步问题的内核对象,线程可以获取或释放它,从而达到同步或互斥的目的。理解资源计数适合于线程间工作处理速度不匹配的场合;信号量在大于0时才能获取,在中断、线程中均可释放信号量。 为了体现使用信号量来达到线程间的同步,…

【STM32】西南交大嵌入式系统设计实验:环境配置

把走过的坑记录一下&#xff0c;希望后来人避坑 No ST-Link device detected.问题解决 如果跟着指导书出现这个问题&#xff1a; 直接跳过这一步不用再更新固件&#xff0c;后面直接创建项目写程序就行了。 在keil里配置成用DAP_link即可。 详细的可以看这篇文章&#xff1a…

NumPy基础及取值操作

文章目录 第1关&#xff1a;ndarray对象第2关&#xff1a;形状操作第3关&#xff1a;基础操作第4关&#xff1a;随机数生成第5关&#xff1a;索引与切片 第1关&#xff1a;ndarray对象 编程要求 根据提示&#xff0c;在右侧编辑器Begin-End中填充代码&#xff0c;根据测试用例…

Oracle 数据库 count的优化-避免全表扫描

Oracle 数据库 count的优化-避免全表扫描 select count(*) from t1; 这句话比较简单&#xff0c;但很有玄机&#xff01;对这句话运行的理解&#xff0c;反映了你对数据库的理解深度&#xff01; 建立实验的大表他t1 SQL> conn scott/tiger 已连接。 SQL> drop table …

Fiddler工具的操作和功能时-----定位到步骤图(助力抓包)

前言&#xff1a; 继续上一篇&#xff0c;已经对fiddler的安装、配置和代理的问题进行了讲解&#xff1a; Fiddle配置代理&#xff0c;保手机模拟器访问外部网络-CSDN博客 本章&#xff0c;讲对一些fiddler的操作进行一系列讲解&#xff01;Fiddler作为一款网络调试工具&…

可视化大屏的应用(13):3D建模运用到机房运维中

可视化大屏在机房运维中发挥着重要的作用&#xff0c;主要体现在以下几个方面&#xff1a; 实时监控 通过可视化大屏&#xff0c;可以实时监控机房的各项指标和状态&#xff0c;如服务器的运行状态、网络流量、机房温度等。运维人员可以通过大屏快速获取关键信息&#xff0c;…