热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

java配列add,Javaday14

###1、Set集合的特点:(1)无序(存储和读取的顺序有肯不一样);(2)不允许重复(要求元素唯一);(3)没有索引###2、HashS

###1、Set集合的特点: (1)无序(存储和读取的顺序有肯不一样); (2)不允许重复(要求元素唯一); (3)没有索引 ###2、HashSet有三种遍历集合对象的方式: (1)转换成数组; (2)迭代器; (3)增强for 例: package com.itheima; import java.util.HashSet; import java.util.Iterator; import java.util.Set; public class HashSetDemo { public static void main(String[] args) { //创建集合对象 //HashSet hs=new HashSet(); Set set=new HashSet();//父接口引用指向指向子类对象 //添加元素对象 set.add("hello"); set.add("world"); set.add("java"); //遍历集合对象 //method(set); //method1(set); for(String s:set) { System.out.println(s); } }

public static void method1(Set set) {

//迭代器

Iterator it=set.iterator();

while(it.hasNext()) {

String s=it.next();

System.out.println(s);

}

}

public static void method(Set set) {

//转换成数组

Object[] obj=set.toArray();

for(int i =0;i

System.out.println(obj[i]);

}

}

}

###3、HashSet的add()方法的去重功能: (1)当前集合中的每一个元素和新添加的元素进行hash值比较; (2)如果hash值不一样,则直接添加新元素;如果hash值一样,则比较地址值或者使用equals方法进行比较; (3)如果比较的结果一样,则认为是重复不添加;如果比较的结果不一样,则添加 以Person类为例: @Override public String toString() { return "Person [name=" + name + ", age="+ age + "]"; } @Override public int hashCode() { return age+name.hashCode(); } @Override public boolean equals(Object obj) { System.out.println("---------"); //提高效率 if(this==obj) { return true; } if(this.getClass()!=obj.getClass()) { return false; } //向下转型 Person p=(Person)obj; if(!this.name.equals(p.name)) { return false; } if(this.age!=p.age) { return false; } return true; } 注意: 去重中提高程序效率的方法: 让成员变量不同的对象,他们的返回值也不同,即让HashCode()方法的返回值和对象的成员变量有关,可以让HashCode()方法返回所有成员变量之和(基本数 据类型直接相加;引用数据类型获取HashCode()方法返回值后再相加(boolean不可以参与运算)) ###4、Collection和Collections的区别: (1)Collection是集合体系的最顶层,包含了集合体系的共性; (2)Collections是一个工具类,方法都是用于操作Collection Collections中的一些基本操作: (1)static void swap(List list,int i,int j):将指定列表中的两个索引进行位置互换; (2)static void sort(List list):按照列表中元素的自然顺序进行排序; (3)static void shuffle(List list):随机置换; (4)static void reverse(List list):反转; (5)static void fill(List list,Object obj):使用指定的对象填充指定列表的所有元素; (6)static void copy(List dest,List src):把源列表中的数据覆盖到目标列表中; (7)static void binarySearch(List list,Object key):使用二分查找法查找指定元素在指定列表的索引位置 ###5、Map:专门用于存储对应关系的集合 Map和Collection的区别: (1) Map:是一个双列集合,常用于处理有对应关系的数据,其中key是不能重复的; (2)Collection:是单列集合,有不同的子体系,有的允许重复索引,有序;有的不允许重复索引,无序 注意: Map是将键映射到值的对象。一个映射不能包含重复的键,每个键最多只能映射到一个值(一对一关系) Map的常用功能: (1)V put(K key,V value):将key映射到value,如果key存在,则覆盖value,并将原来的value返回; (2)void clear():清空所有的对应关系; (3)V remove(Object key):根据指定的key删除对应关系,并返回key所对应的值,如果没有删除成功,则返回null; (4)boolean containsKey(Object key):判断指定key是否存在; (5)boolean containsValue(Object value):判断指定value是否存在; (6)boolean isEmpty():判断是否有对应关系; (7)int size():返回对应关系的个数; (8)V get(Object key):根据指定的key返回对应的value; (9)Collection values():以collection的形式返回所有的value; (10)Set keySet():以set的形式返回所有的key 遍历Map的两种方式: 例: (1)遍历Map对象(第一种方式) Set keys=map.keySet(); for(String key:keys) { String value=map.get(key); System.out.println("编号:"+key+"姓名:"+value); (2)遍历Map对象(第二种方式) Set> entrys=map.entrySet(); for(Map.Entry entry:entrys) { String key=entry.getKey(); String value=entry.getValue(); System.out.println("编号:"+key+"姓名:"+value); 注:HashMap的遍历和Map一样,并且可以实现去重,相同编号的后面会覆盖前面的 ###6、异常的体系结构: (1)Throwable(最顶层); (2)Error:出现不能够处理的严重问题; (3)Exception:可以处理的问题 异常是在写代码时出现编译或者运行错误,包含了错误的类型,原因以及位置 ###7、异常的处理方式: 捕获处理 try----catch语句 try{ 可能出现问题的代码; }catch(异常对象){ 处理异常; } 注意:jvm处理异常的方式: 如果出现异常我们没有处理,jvm会帮我们进行处理,他会把异常的类型,原因已经位置显示在命令行,并且终止程序,异常后面的代码将不再执行 ###8、处理多个异常: (1)使用多个try---catch语句; (2)使用一个try和多个catch 注意:多个catch之间的顺序: (1)多个catch之间可以有子父类; (2)同级之间没有顺序关系; (3)如果有子父类,父类异常必须在后面 ###9、Throwable的常用方法: (1)String getMessage():原因; (2)String toString():类型和原因; (3)void printStackTrace():类型、原因和位置 ###10、finally:组合try---catch使用,用于释放资源等收尾工作,无论try---catch语句如何执行,finally的代码一定会执行 格式: try{ 可能出现问题的代码; }catch(异常对象){ 处理异常; }finally{ 释放资源; 清理垃圾; } ###11、异常的分类: (1)运行时期异常:RuntimeException的子类,在编译时期可以自由选择处理或者不处理; (2)编译时期异常:Exception的子类,不是RuntimeException的子类,在编译时期必须处理(抛出或捕获) ###12、throws和throw的区别: (1)throws:处理异常的一种方式,把异常抛出,由调用者来处理; (2)throw:制造异常的方式,并且结束方法 注意:如果抛出(throw)的是编译时期的异常,必须在方法声明处抛出(throws) 定义异常类的方法:写一个类去继承 RuntimeException或 Exception,然后实现多个构造 ###13、递归:在方法本身不断的调用方法自己 注意: (1)递归一定要由出口,否则会内存溢出; (2)递归次数不宜过多,否则会内存溢出



推荐阅读
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 本文详细介绍了Java中org.neo4j.helpers.collection.Iterators.single()方法的功能、使用场景及代码示例,帮助开发者更好地理解和应用该方法。 ... [详细]
  • 主要用了2个类来实现的,话不多说,直接看运行结果,然后在奉上源代码1.Index.javaimportjava.awt.Color;im ... [详细]
  • 将Web服务部署到Tomcat
    本文介绍了如何在JDeveloper 12c中创建一个Java项目,并将其打包为Web服务,然后部署到Tomcat服务器。内容涵盖从项目创建、编写Web服务代码、配置相关XML文件到最终的本地部署和验证。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 本文介绍了如何通过 Maven 依赖引入 SQLiteJDBC 和 HikariCP 包,从而在 Java 应用中高效地连接和操作 SQLite 数据库。文章提供了详细的代码示例,并解释了每个步骤的实现细节。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
  • andr ... [详细]
  • Scala 实现 UTF-8 编码属性文件读取与克隆
    本文介绍如何使用 Scala 以 UTF-8 编码方式读取属性文件,并实现属性文件的克隆功能。通过这种方式,可以确保配置文件在多线程环境下的一致性和高效性。 ... [详细]
  • 本文提供了使用Java实现Bellman-Ford算法解决POJ 3259问题的代码示例,详细解释了如何通过该算法检测负权环来判断时间旅行的可能性。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 本文深入探讨了 Java 中的 Serializable 接口,解释了其实现机制、用途及注意事项,帮助开发者更好地理解和使用序列化功能。 ... [详细]
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
author-avatar
壹起等绿灯
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有