热门标签 | 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注解的基本概念及其在现代Java开发中的应用。文章不仅介绍了如何创建和使用自定义注解,还详细讲解了如何利用反射机制解析注解,以及Java内建注解的使用场景。 ... [详细]
  • 在现代多线程编程中,Lock接口提供的灵活性和控制力超越了传统的synchronized关键字。Lock接口不仅使锁成为一个独立的对象,还提供了更细粒度的锁定机制,例如读写锁(ReadWriteLock)。本文将探讨如何利用ReentrantReadWriteLock提高并发性能。 ... [详细]
  • 一个产品数组拼图|集合 2 (O(1)空间) ... [详细]
  • 快速排序是基于分治策略的一种排序算法,其平均时间复杂度为O(n log n),在大多数情况下表现优于其他排序算法。本文将详细介绍快速排序的工作原理,并提供一个Java语言的具体实现。 ... [详细]
  • 近期参加了一次CSDN线上活动,有幸获得左飞老师的《算法之美——隐匿在数据结构背后的原理(C++版)》一书。为了加深理解并提升编程技能,我决定将书中22个经典算法问题使用Java语言进行重新编写。本文将重点介绍如何使用Java实现Z字形矩阵排列。 ... [详细]
  • 快速排序是一种高效的排序算法,以其在多数情况下接近最优的性能而著称。本文将详细介绍如何在 Java 中实现快速排序,并分析其工作原理。 ... [详细]
  • 线程是创建并发的底层工具,因此具有一定的局限性。没有简单的方法可以从联合(Join)线程得到“返回值”。因此必须创建一些共享域。当抛出一个异常时,捕捉和处理异常也是麻烦的。线程完成之后,无法再次启动该 ... [详细]
  • 本文详细介绍了 C# 编程语言中 Main 方法的作用、不同形式及其使用场景,帮助开发者更好地理解和应用这一重要概念。 ... [详细]
  • Android json字符串转Map
    Androidjson字符串转Map,Go语言社区,Golang程序员人脉社 ... [详细]
  • jme-燃烧的火焰
    jme的粒子效果也让人炫目:publicclassHelloParticleextendsSimpleApplication{publicstaticvoid ... [详细]
  • 本文深入探讨了企业级开发框架NHibernate和Spring.NET的关键特性之一——面向方面编程(AOP)。文章不仅介绍了AOP的基本概念及其如何增强面向对象编程(OOP),还详细说明了Spring.NET中AOP的具体应用,包括事务管理和自定义方面的实现。 ... [详细]
  • 本文介绍了一种利用迭代法解决特定方程问题的方法,特别是当给定函数f(x)在区间[x1, x2]内连续且f(x1)0时,存在一个x~使得f(x~)=0。通过逐步细化搜索范围,可以高效地找到方程的根。 ... [详细]
  • 本文章介绍了如何将阿拉伯数字形式的金额转换为中国传统的大写形式,适用于财务报告和正式文件中的金额表示。 ... [详细]
  • 学习目的:1.了解android线程的使用2.了解主线程与子线程区别3.解析异步处理机制主线程与子线程:所谓主线程,在Windows窗体应用程序中一般指UI线程,这个是程序启动的时 ... [详细]
  • Python图像处理库概览
    本文详细介绍了Python中常用的图像处理库,包括scikit-image、Numpy、Scipy、Pillow、OpenCV-Python、SimpleCV、Mahotas、SimpleITK、pgmagick和Pycairo,旨在帮助开发者和研究人员选择合适的工具进行图像处理任务。 ... [详细]
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社区 版权所有