热门标签 | 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)递归次数不宜过多,否则会内存溢出



推荐阅读
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 使用GDI的一些AIP函数我们可以轻易的绘制出简 ... [详细]
  • 深入理解Redis的数据结构与对象系统
    本文详细探讨了Redis中的数据结构和对象系统的实现,包括字符串、列表、集合、哈希表和有序集合等五种核心对象类型,以及它们所使用的底层数据结构。通过分析源码和相关文献,帮助读者更好地理解Redis的设计原理。 ... [详细]
  • 本文将深入探讨如何在不依赖第三方库的情况下,使用 React 处理表单输入和验证。我们将介绍一种高效且灵活的方法,涵盖表单提交、输入验证及错误处理等关键功能。 ... [详细]
  • 深入解析Redis内存对象模型
    本文详细介绍了Redis内存对象模型的关键知识点,包括内存统计、内存分配、数据存储细节及优化策略。通过实际案例和专业分析,帮助读者全面理解Redis内存管理机制。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 本文探讨了 Objective-C 中的一些重要语法特性,包括 goto 语句、块(block)的使用、访问修饰符以及属性管理等。通过实例代码和详细解释,帮助开发者更好地理解和应用这些特性。 ... [详细]
  • 本文探讨了如何优化和正确配置Kafka Streams应用程序以确保准确的状态存储查询。通过调整配置参数和代码逻辑,可以有效解决数据不一致的问题。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 深入理解Java泛型:JDK 5的新特性
    本文详细介绍了Java泛型的概念及其在JDK 5中的应用,通过具体代码示例解释了泛型的引入、作用和优势。同时,探讨了泛型类、泛型方法和泛型接口的实现,并深入讲解了通配符的使用。 ... [详细]
  • 本文探讨了在Java多线程环境下,如何确保具有相同key值的线程能够互斥执行并按顺序输出结果。通过优化代码结构和使用线程安全的数据结构,我们解决了线程同步问题,并实现了预期的并发行为。 ... [详细]
  • 对象自省自省在计算机编程领域里,是指在运行时判断一个对象的类型和能力。dir能够返回一个列表,列举了一个对象所拥有的属性和方法。my_list[ ... [详细]
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社区 版权所有