集合框架(二)

2023-11-18

集合框架(二)

回顾

Collection、List、Set的特点

Collection:不唯一的,无序的

List:不唯一的 有序

Set:唯一的 无序的

Collection和Collections的区别?

Collection是集合的顶级接口

Collections是集合的工具类

ArrayList的常用API

存储数据:

​ boolean add(Object obj); 向集合后追加元素

​ void add(int index,Object obj); 向集合的指定位置添加元素 原有位置元素 依次后移

删除数据:

​ remove(int index); 根据下标来删除元素

​ remove(Object obj); 将指定值删除

获取集合的长度: size();

**获取集合中的元素:**get(int index);

**判断集合中是否包含指定元素:**contains(Object obj);

LinkedList的常用API

addFirst(Object obj);

addLast(Object);

removeFirst();

removeLast();

getFirst();

getLast();

ArrayList和LinkedList的区别

ArrayList 底层是数组结构,它在每一次增删时都会重新创建新的数组,所以在增删方面效率比较低。因为数组有固定的下标,所以在查询方面效率比较高。

LinkedList 底层是链表结构(数据值和指针域组成) ,在增删方面尤其是首尾增删效率比较高,但是因为没有固定的下标,所以在查询方面效率比较低。

HashSet

equals() hashcode()

集合的遍历

ArrayList:

​ 1.for(int i = 0; i < list.size(); i++){

​ }

​ 2.增强for

​ for(临时类型 临时的变量名 : 集合名){

​ }

​ 3.迭代器

Iterator<xxx>   iterator = list.iterator();
	while(iterator.hasNext()){
​			iterator.next();}

LinkedList:

​ 同上!

HashSet:

​ 1.增强for

​ 2.迭代器

1.Map的使用

HashMap

HashTable

课程编码和课程信息对应的需求。

BD001 -> Java课程

BD002 -> UI课程

BD003 -> C#课程

Key -Value 键值对 夫妻对!

常用API
  1. put(Object key,Object value); 存储键值对
  2. get(Object key); 根据键(唯一的)获取值
  3. containsKey(Object key); 判断是否包含指定键
  4. containsValue(Object value); 判断是否包含指定值
  5. size(); 获取集合长度
  6. Set keySet(); 获取所有键集合
  7. Collection values(); 获取所有值的集合
  8. clear(); 清空所有数据
Map集合的遍历
  1. 使用迭代器

    1.1Map集合获取所有的键集合

    1.2遍历键集合(迭代器),然后通过键获取值

  2. 使用增强for

    2.1Map集合获取所有的键集合

    2.2遍历键集合(增强for),然后通过键获取值

  3. 使用键值对集合

    3.1Map集合获取entrySet(键值对的Set集合)

    3.2遍历entrySet将其中每一个entry取出来

    3.3从entry中将键和值取出来

public static void main(String[] args) {

		// 创建集合
		Map<String,String> map = new HashMap<String,String>();
		// 添加到集合中   存储时无序
		map.put("CN", "中国");
		map.put("US", "美国");
		map.put("UK", "英国");
		
		// 键必须唯一   值可以重复
		// 如果给相同的key进行赋值  那么会进行覆盖(更新)
		map.put("CN", "中国1");
		
		System.out.println("---------------1--------------------");
		Collection<String> values = map.values(); // 所有值的集合
		for (String value : values) {
			System.out.println(value);
		}
		
		System.out.println("----------------2-------------------");
		Set<String> keySet = map.keySet();//所有键的集合
		for (String key : keySet) {
			System.out.println(key);
			//根据键获取值
			String value = map.get(key);
			System.out.println("打印值"+value);
		}
		
		//可以用map的迭代器遍历
		Iterator<String> iterator = keySet.iterator();
		while(iterator.hasNext()) {
			String key = iterator.next();
			String value = map.get(key);
			System.out.println(key +"=="+value);
		}
		
		
		System.out.println("---------------3--------------------");
		//获取所有键值对集合
		Set<Entry<String, String>> entrySet = map.entrySet();
		for (Entry<String, String> entry : entrySet) {
			System.out.println(entry);
			String key = entry.getKey(); // 获取键
			String value = entry.getValue();//获取值
			System.out.println(key+"   -- >    "+value);
		}
		
		//可以用map的迭代器遍历
		Iterator<Entry<String, String>> iterator2 = entrySet.iterator();
		while(iterator.hasNext()) {
			Entry<String, String> next = iterator2.next();
			String key = next.getKey();
			String value = next.getValue();
			System.out.println(key +"=="+value);
		}
		
	}

2. 泛型的作用

包装类型

必须使用引用数据类型

public class Demo3 {
    public static void main(String[] args) {

        // 泛型:用来限制集合中元素的类型(获取数据后可以不用强转)
        // 泛型在限定类型时,类型必须是引用数据类型
        // int -> Integer
        /*ArrayList<Integer> arrayList = new ArrayList<Integer>();
        arrayList.add(20);*/

        // double -> Double
        /*ArrayList<Double> arrayList = new ArrayList<Double>();
        arrayList.add(20.1);
        System.out.println(arrayList);*/
        // byte -> Byte
        // short -> Short
        // long -> Long
        // float -> Float
        // boolean -> Boolean
        // char -> Character

        // 基本数据类型是没有方法和属性(类的信息)的
        Integer a = 10;
    }
}

3. Collections的了解

常用API
  1. sort(集合); 给集合进行排序 升序
		List<Integer> list=Arrays.asList(1,7,2,3,6,5);
		Collections.sort(list);
		System.out.println(list);//[1, 2, 3, 5, 6, 7]
  1. max() / min() 获取最大值 最小值
  2. shuffle() 打乱集合内元素
public static void main(String[] args) {
		List<Integer> list=Arrays.asList(1,2,3,6,5);
		Integer max = Collections.max(list);
		System.out.println(max);//输出最大值6
	}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

集合框架(二) 的相关文章

随机推荐

  • 知识图谱实现步骤和用到的方法

    PDF 下载 https download csdn net download nrlovestudy 10938925 参考资料 1 知识图谱入门 一 知识图谱与语义技术概览 https blog csdn net pelhans art
  • 【CSS】background相关属性深入学习

    最近一次需求中对于background相关的一些属性使用较多 总结下 希望提高下次的开发效率 background属性 background color background image background position backgr
  • .NET面试题——第7篇 C#类和对象

    1 什么是类和对象以及关系 对象 一种具有状态 属性 和行为 方法 的编程实体 用于描述现实世界的某个具体事物 类 具用一系列对象共同特征和行为的通用类型 对象和类的关系 类是对象的抽象 而对象是类的具体实例 类是抽象的 不占用内存 而对象
  • go爬虫框架colly的精简讲解

    1 拉取软件包 go get github com gocolly colly 2 创建colly的收集器 colly NewCollector 可以在创建的时候进行配置 c colly NewCollector colly AllowUR
  • Java 断点调试 循环调试

    java断点调试 以eclipse为例 1 基础调试 这里都是一些基础 除了最后一个都十分常用 名称 快捷键 作用 Resume F8 运行至下一断点 Step Into F5 进入方法 Step Over F6 运行完当前语句 User
  • PCL 点云按高程渲染颜色

    目录 一 算法原理 二 代码实现 三 结果展示 四 CloudCompare 五 备注 一 算法原理 首先按照Z轴方向求取所在点云的高程极值 包括高程最大值与最小值 计算高程中值 然后选取渲染的红 绿 蓝三种颜色的值 最后 自上而下 为红绿
  • NBA的字母哥如何拿到2415万美金年薪

    前言 NBA是世界上最成功的体育联盟之一 为了制定合理的运作规范 联盟会与球员工会签署劳资协议 协议里规定了球队的工资帽 一支球队球员工资总额的上限 顶薪 球员薪水的上限 底薪 球员的最低薪水 和其他规范 2011年 经历了停摆事件 联盟和
  • 一张图理清ASP.NET Core启动流程

    1 引言 对于ASP NET Core应用程序来说 我们要记住非常重要的一点是 其本质上是一个独立的控制台应用 它并不是必需在IIS内部托管且并不需要IIS来启动运行 而这正是ASP NET Core跨平台的基石 ASP NET Core应
  • JS 数组定义及详解

    一 数组简介 1 什么是数组 数组是值的有序集合 每个值叫做元素 每个元素在数组中都有数字位置编号 也就是索引 JS中的数组是弱类型的 数组中可以含有不同类型的元素 数组元素甚至可以是对象或其他数组 例如 var arr 1 true nu
  • kubernetes运维---calico之ipip模式抓包分析

    一 calico介绍 Calico是Kubernetes生态系统中另一种流行的网络选择 虽然Flannel被公认为是最简单的选择 但Calico以其性能 灵活性而闻名 Calico的功能更为全面 不仅提供主机和pod之间的网络连接 还涉及网
  • 功能实现:Unity中一个动画,只播放中间指定的一截,而且循环播放

    一 要播放的动画 直播中间一截 如图 总的动画为长度为2分钟零8秒 二 Button和对应事件 三 事件的代码 在Start 里面绑定 private void Awake myAnim animGo GetComponent
  • Flutter实现app自动升级

    话不多说 有过开发过移动应用的人都应该自动升级流程 首先获取本地应用版本 然后从服务器获取线上移动应用版本号作比较是否升级 第一步获取版本信息 API https pub dev packages package info 获取应用版本号
  • iview on-change用法

    原地址 https segmentfault com q 1010000011589626 iview框架select选择框on change事件如何返回当前选中的值 这是文档中的解释 on change 选中的Option变化时触发 默认
  • C++类与封装实例说明

    众所周知 C 具有三大特性 分别为封装 继承 多态 今天有位同学问到我应该如何去理解 我翻了翻笔记本 找到以前上课时学到的案例来解释 首先 成员函数存在希望公开或不希望公开的属性 这也构成了定义成员函数访问级别的三项 1 public 公开
  • 架构师--IT策略灵魂的创造者

    http blog csdn net aspop archive 2006 01 21 585823 aspx 在比尔 盖茨的众多称谓中 据说他更偏爱 首席软件架构师 同样 在网易创始人丁磊名字前 也有 首席架构师 这样的称谓 对于企业来说
  • IDEA国际化资源Key无法全局重命名的解决方案

    一 前言 最近在开发中使用到了HibernateValidator进行入参校验以及错误消息的国际化支持 大家应该都知道在使用HibernateValidator进行校验的时候 我们只需在需要在校验的变量上添加相应的注解 同时在message
  • Flutter 应用程序更新

    Flutter 应用程序更新 原文 https medium com flutter community in app update the flutter way 2f25e4a02c02 前言 当您推出应用程序的新版本时 您希望您的用户
  • CSS3背景渐变

    我们经常可以看到有些背景色并不是纯色 而是好看的渐变色 css3知我懂我 给我们提供了制作渐变背景色的属性 渐变主要包括线性渐变和径向渐变 接下来逐一介绍用法 1 线性渐变 线性渐变 linear gradients 表示颜色沿着一条直线过
  • 设计模式--原型模式

    原型模式 属于创建型模式 基本原理 又称为克隆模式 拷贝本身对象 可以直接使用语言中的拷贝构造 主要流程 在构建对象的时候实现一个对本身的拷贝函数 特别注意 要有对应的销毁方法 include
  • 集合框架(二)

    集合框架 二 回顾 Collection List Set的特点 Collection 不唯一的 无序的 List 不唯一的 有序 Set 唯一的 无序的 Collection和Collections的区别 Collection是集合的顶级