位置: IT常识 - 正文

Collections类详解(collection的属性)

编辑:rootadmin
Collections类详解

目录

一.Collections概述:

   1.1什么是Collections类:

   1.2 Collections类和collection的区别和联系:

二. Collections类的主要方法:

一.Collections概述:     1.1  什么是Collections类:Java.util.Collections是一个集合工具类,用于操作LIst,Set,Map等集合。Collections类提供了一系列的静态方法,可以实现对集合元素的排序,添加一些元素,随机排序,替换等操作。       注意:Collections类不能new对象,不是因为没有构造方法,而是因为Collections的构造方法被私有化处理了。但是调用方法可以直接通过类名调用Collections类的方法,因为Collections类中的方法都是被static修饰了,可以直接用类名调用。

推荐整理分享Collections类详解(collection的属性),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:collection class,collection的属性,collection类方法,collections常用方法,collections类的作用,collection类的作用,collections类的作用,collections类的作用,内容如对您有帮助,希望把文章链接给更多的朋友!

   1.2 Collections类和collection的区别和联系:

区别:

Collections是一个工具类,有属性和静态方法Collection是一个根接口,下面有List和Set接口,两个接口各有他们具体的实现类。他们只有一个字母的区别,但是两者是完全不同的概念。

联系:

Collctions中提供给collection接口下的Set和List集合许多方法,方便对集合中的元素更好的处理。二. Collections类的主要方法:

Collections中的方法都是静态方法,可以通过类名.方法名直接调用。

1.public static void shuffle(List)。混乱排序   

2.public static <T> boolean addAll(Collection<T> c, T... elements)。添加一些元素

3.public static <T> void sort(List<T> list,Comparator<? super T> )。  排序,将集合中元素按照指定规则排序

4.public static <T extends Comparable<? super T>> void sort(List<T> list)。  排序,将集合中元素按照默认规则排序。

5.public static int binarySearch(List list, Object key)。查找,使用二分搜索法搜索指定的 List 集合,以获得指定对象在 List 集合中的索引。如果要使该方法可以正常工作,则必须保证 List 中的元素已经处于有序状态。

6.public static void copy(List <? super T> dest,List<? extends T> src)  复制, 用于将指定集合中的所有元素复制到另一个集合中。

7.public static void replaceAll()。替换,替换集合中所有的旧元素为新元素

1.shuffle()随机排序:

shuffle方法用于将集合中的元素,随机打乱原来的顺序。

          注意:shuffle中的集合只能是List集合。Set集合会报错。

使用案例:

import java.util.Collections;import java.util.HashSet;import java.util.LinkedList;public class CollectionsTest { public static void main(String[] args) {//创建一个Linkedlist集合 LinkedList linkedList = new LinkedList(); inkedList.add(123); linkedList.add(456); linkedList.add(234); linkedList.add(567); for (int i = 0; i <linkedList.size() ; i++) { System.out.println(linkedList.get(i)); } //打乱顺序 Collections.shuffle(linkedList); System.out.println("==========="); System.out.println("打乱顺序之后:"); for (int i = 0; i <linkedList.size() ; i++) { System.out.println(linkedList.get(i)); } }}

运行结果:

2.  addAll()   添加一些元素:

作用:

addAll方法用于往集合中快速添加一些元素

用法:

第一个形参放集合对象,之后放参数1 ,参数2, 可变参数类型... 。

什么是可变参数类型呢?

方法中的某个参数在实际调用时,实参个数可以0个,或者1个,或者多个。这个参数就是可变参数。可变参数参数的意义:方便方法的调用,可以传入任意多个同类型的数据。

注意点:

如果方法中有多个参数,可变参数要放到最后。

一个方法只能有一个可变参数

使用案例:

1.创建多个学生对象。

2.把学生用addAll方法装入Linkedlist集合中

import java.util.Collections;import java.util.HashSet;import java.util.LinkedList;public class CollectionsTest { public static void main(String[] args) {//创建一个linkedlist集合 LinkedList linkedList = new LinkedList(); Student student1 = new Student(1, "章1"); Student student2 = new Student(6, "章2"); Student student3 = new Student(9, "章3"); Student student4 = new Student(1, "章4");Collections.addAll(linkedList,student1,student2,student3,student4);for (int i = 0; i <linkedList.size() ; i++) { System.out.println(linkedList.get(i)); }

运行结果:

3. sort()自然排序:

作用:

Collections类详解(collection的属性)

把集合中的元素按照规则升序或者降序,再或者什么也不干。

注意点:

当使用sort方法时,该集合元素必须是Comparable的子类型,也就是集合中的元素必须实现comparable接口中的comparaTo方法。否则不能使用该方法。

public int compareTo(T o);

必须实现这个抽象方法,才能使用sort方法。但是由于我们一些基本的常用类如String,基本数据类型的包装类等,已经实现了该方法,所以我们不需要自己重写该方法了。自定义类型使用sort方法就必须实现comparaTo方法。

4.sort()自定义排序:

自定义类型,如学生类,有属性:年龄,姓名等。创建多个学生类对象,放入List集合中。自定义使用sort方法时就必须重写comparaTo方法。

@Override public int compareTo(Student2 o) { return this.age-o.age; }

重写之后的comparaTo方法。 

重载之后的sort():

sort()方法还有第二种类型(collection,new Comparator<Object>)

Comparator是一个接口,实际上是new了Comparator的实现类,但是要实现里面的抽象方法。

使用案例:

1.自定义一个学生类,有年龄,姓名,成绩属性。

2.创建5个学生对象,然后根据他们年龄大小实现年龄升序和成绩降序输出。

import java.util.Collections;import java.util.LinkedList;public class CollectionsTest2 { public static void main(String[] args) { LinkedList linkedList = new LinkedList(); Student2 student1 = new Student2(10, "章1"); Student2 student2 = new Student2(16, "章2"); Student2 student3 = new Student2(19, "章3"); Student2 student4 = new Student2(18, "章4"); //把对象添加到集合中 Collections.addAll(linkedList,student1,student2,student3,student4); Collections.sort(linkedList); for (int i = 0; i <linkedList.size() ; i++) { System.out.println(linkedList.get(i)); } }}class Student2 implements Comparable<Student2>{ int age; String name; public Student2(int age, String name) { this.age = age; this.name = name; } @Override public String toString() { return "Student2{" + "age=" + age + ", name='" + name + '\'' + '}'; } @Override public int compareTo(Student2 o) { return this.age-o.age; }}

 

注意点:

1.按照某种规则排序,是重写comparaTo方法时,用什么属性去比较,这个比较的属性就是比较规则排序。

2.实现升序或者降序规则:this(当前调用方法的对象)  o(参数传入)         所有比较最底层的逻辑都是发生两两比较逻辑,返回比较结果         正数  this.age > o.age         负数  this.age < o.age         0     this.age==o.age。

6.copy()  复制:

 作用:将指定集合中的所有元素复制到另一个集合中。

 使用:

(List <? super T> dest,List<? extends T> src)

dest是目标集合,src是原集合。把原集合中的元素放到目标集合中。

使用注意点:

1。原集合复制到目标集合中去,原集合会覆盖掉目标集合中元素,这个覆盖从索引值为0开始覆盖,直到原集合复制完毕。

2.目标集合的长度至少和源集合的长度相同,如果目标集合的长度更长,则不影响目标集合中的其余元素。如果目标集合长度不够而无法包含整个源集合元素,程序将抛出 IndexOutOfBoundsException 异常。

3.copy方法也只能复制List集合,不能复制set集合

个人见解:由于会覆盖掉目标集合的元素,我觉得没有太多的用处

使用案例:

1.把集合1赋值到集合2中

import java.util.Collections;import java.util.HashSet;import java.util.LinkedList;public class CollectionsTest2 { public static void main(String[] args) { LinkedList linkedList = new LinkedList(); LinkedList linkedList1 = new LinkedList();//创建两个set集合 HashSet hashSet = new HashSet(); HashSet hashSet1 = new HashSet(); linkedList1.add(123); linkedList1.add(222); linkedList.add(333); linkedList.add(444); linkedList.add(888); hashSet.add(234); hashSet1.add(666); Collections.copy(linkedList, linkedList1); //使用copy方法复制set会报错// Collections.copy(hashSet,hashSet1); for (int i = 0; i < linkedList.size(); i++) { System.out.println(linkedList.get(i));// } } }}

运行结果:

7.replaceAll()。替换:

作用:替换集合中所有的旧元素为新元素

使用:

(List list, Object oldVal, Object newVal)

list需要替换的集合,oldval需要被替换的值,newval新的值

使用案例:

把集合中的333替换成字符串“8888”

import java.util.Collections;import java.util.HashSet;import java.util.LinkedList;public class CollectionsTest2 { public static void main(String[] args) { LinkedList linkedList = new LinkedList(); linkedList.add(123); linkedList.add(222); linkedList.add(333); linkedList.add(444); linkedList.add(888); hashSet.add(234); hashSet1.add(666);//替换 Collections.replaceAll(linkedList,333,"8888"); for (int i = 0; i < linkedList.size(); i++) { System.out.println(linkedList.get(i));// } } }}
本文链接地址:https://www.jiuchutong.com/zhishi/299767.html 转载请保留说明!

上一篇:troff命令 格式化打印机和字符终端的文本(trace 命令用法)

下一篇:JS解构赋值(js解构赋值浏览器报错)

  • 房地产企业样板房会计处理
  • 个人所得税包括绩效工资吗
  • 住宿费抵扣进项税怎么报税
  • 筹建期间发生的开办费计入什么科目
  • 合并报表是把资产负债表相加吗
  • 教育行业主营业务内容
  • 定额发票可以用旧的营业执照发票章吗
  • 资信证明好开吗
  • 小规模纳税人不允许开具零税率发票
  • 汽车进口税率表
  • 应交税费里的应交企业所得税意思是交了吗
  • 应付利息与应付利息区别
  • 计提公司所得税分录
  • 季度企业所得税申报表怎么填写
  • 接受实物投资的增值税会计核算方法
  • 营改增后,企业购进自用小轿车增值税
  • 其他应付款质保金到期怎么附单据
  • 预付卡销售加油充值款可以报销吗
  • 上个月开的发票退回怎么处理?
  • 以前年度少计收入 会计怎么处理
  • 预提费用怎么理解
  • 一般纳税人是否享受小型微利企业优惠政策
  • 固定资产减值准备可以税前扣除吗
  • macbook右上角
  • 招待客户住宿费可以抵扣进项税吗合理吗
  • 确认收入是收到款了吗
  • 用友软件查其他业务收入怎么查
  • 企业取得财政拨款怎么算
  • 职工福利费属于什么科目?
  • 弥补亏损需要注意的事项
  • 苹果电脑字体文件怎么拖出来
  • fodhelper.exe是什么程序
  • php的mysql_query
  • 提足折旧仍使用的逾龄房产是否交房产税
  • 企业固定资产计提折旧是以什么为前提
  • 发票填开有哪些规范性要求
  • 葡萄酒企业已纳税多少
  • 出口已使用的设备退税还是免税
  • 微信小程序用电脑怎么打开
  • 个体户做账流程新手必看
  • 织梦cms为什么不维护了
  • 帝国cms移动端
  • 织梦一直显示上一页和下一页
  • 营业总成本包括投资收益吗
  • 如何确定固定资产的原始成本
  • 个体户核定征收和查账征收哪个好
  • 在建工程转入
  • 其他收益属于什么类科目
  • 不征税收入怎么做会计分录
  • 待认证进项税额月末怎么处理
  • 会计分录如何分配利润
  • 工人发生工伤的责任划分
  • 餐饮业燃气费计入什么科目
  • 基金会收到捐款的会计分录
  • 开票信息中电话怎么填
  • mysql单表数据建议
  • Windows 2008 R2 AD组策略-统一域用户桌面背景详细图文教程
  • windows集群运行
  • win11注意
  • Linux Mount NTFS分区造成的权限问题如何解决?
  • js excel导入导出
  • nodejs bull
  • perl语句
  • cocos2dx视频教程
  • opengl glbegin
  • macos安装过程
  • android实战教程
  • node.js中的http.get方法使用说明
  • javascript核心技术
  • javascript学习指南
  • 安卓手机管家怎么关闭
  • 轻松实现js图片识别
  • android获取手机的基本信息
  • javascript面向对象吗
  • 广东高速费用支付宝支付如何开发票
  • 学什么专业可以在税务局上班
  • 中欧班列补贴政策
  • 养老专业在职研究生好吗
  • 计算出口退税的免抵税额,不计征城市维护建设税
  • 股息税怎么计算
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设