遍历集合的常见方式,排序,用lambda表示是怎样的
Collection集合的功能:
Object[] toArray() 将集合转成数组
Iterator iterator() 通过方法的调用 获取Iterator迭代器对象
// 遍历集合的常见方式
//方式1 Object[] toArray() 将集合转成数组
//普通for 循环 遍历集合 toArray()方法 将集合转成Object[]数组
Object[] arr = c.toArray();
for(int i=0;i<arr.length;i++){
System.out.println(arr[i]);
}
Collection c2 = new ArrayList();
c2.add(new Student("王二麻子",20));
c2.add(new Student("赵四",40));
Object[] arr2 = c2.toArray();
for(int i=0;i<arr2.length;i++){
//向下转型
Student s = (Student)arr2[i];
System.out.println(s.getName());
}
//方式2 增强for循环
/*
格式
for(元素类型 变量名:要遍历的范围){
循环体语句
}
变量名 随便写
但是在增强for循环中 它代表的是当前遍历范围内的元素本身
缺点:
丢掉了索引
就不能根据索引获取元素了
*/
for(Object o:arr2){
System.out.println(o);//arr2[i] 元素本身
//向下转型
Student s = (Student)o;
System.out.println("增强for 循环:::::"+s.getName());
}
int[] arr3 ={1,2,3};
for(int x:arr3){
System.out.println(x);
}
迭代器:
public static void main(String[] args)
{
Collection c = new ArrayList();
c.add("a");
c.add("b");
c.add("c");
c.add("d");
System.out.println(c);
c.add("qqq");
//Iterator iterator() 迭代器
Iterator it = c.iterator();
/*
boolean hasNext() 如果仍有元素可以迭代,则返回 true。
Object next() 返回迭代的下一个元素。
void remove() 从迭代器指向的 collection 中移除迭代器返回的最后一个元素(可选操作)。
*/
//循环的结束条件是什么 hasNext()--> false 就结束
while(it.hasNext()){
Object obj = it.next();
System.out.println(obj);
if("b".equals(obj)){//为了避免出现空指针异常 在使用equals进行比较时 建议将常量写在前面
//it.remove();
//c.remove("b");//ConcurrentModificationException 多线程并发访问异常
}
}
c.add("cccc");
c.remove("a");
System.out.println(c);
}
/*list
增
add(index,element)在指定位置添加元素 角标从0开始
addAll(index,Collection)
删
remove(index)删除指定位置的元素 角标从0开始
改
set(int index, E element) 修改指定位置的元素 角标从0开始
查
get(int index) 获取指定位置的元素
subList(int fromIndex, int toIndex)
*/
创建List 集合 存储Student对象 并对其进行排重处理
public static void main(String[] args)
{
//创建List 集合 存储Student对象 并对其进行排重处理
List list = new ArrayList();
list.add(new Student("张飞",30));
list.add(new Student("诸葛亮",40));
list.add(new Student("曹操",50));
list.add(new Student("诸葛亮",40));
System.out.println(list);
ArrayList newList = getSingle(list);
System.out.println(newList);
}
public static ArrayList getSingle(List list){
ArrayList al = new ArrayList();
Iterator it = list.iterator();
while(it.hasNext()){
Object obj = it.next();
if(!al.contains(obj)){//contains 包含 底层依托的是equals方法 Object类 默认equals方法比较的是地址值
al.add(obj);
}
}
return al;
}
}

student类中的contains 包含 底层依托的是equals方法 Object类 默认equals方法比较的是地址值
//重写 equals方法 比较属性是否相同 (不会看15)
public boolean equals(Object obj){
if(!(obj instanceof Student)){
return false;
}
Student stu = (Student)obj;
return this.name.equals(stu.name) && this.age == stu.age;
}
List集合特有的迭代器ListIterator
hasNext()
next()
注意 指针 先向后移动 再移动回来 单独写previous 获取不到数据 必须
先将指针向后移动 才能向前移动
hasPrevious()
previous()
//List集合特有的迭代器 ListIterator
List list = new ArrayList();
list.add(new Student("张三", 23));
list.add(new Student("李四", 24));
list.add(new Student("王五", 25));
for(int i=0;i<list.size();i++){
Student stu = (Student)list.get(i);
System.out.println(stu.getName()+",,,"+stu.getAge());
}
//ListIterator
ListIterator it = list.listIterator();
while(it.hasNext()){
Student stu = (Student)it.next();
System.out.println("ListIterator::::"+stu.getName());
if("张三".equals(stu.getName())){
it.add(new Student("赵四", 44));
}
}
System.out.println(list);
//注意 指针 先向后移动 再移动回来 单独写previous 获取不到数据 必须 先将指针向后移动 才能向前移动
while(it.hasPrevious()){
System.out.println("结果:"+it.previous());
}
}
Vector
Vector集合 底层是数组
Vector 和 ArrayList使用方法一样
遍历方式不同
Enumeration<E> elements()
枚举遍历 只能是Vector使用 高版本的List集合无法使用
实际开发中 使用近乎都是ArrayList
public static void main(String[] args) {
Vector v = new Vector();
v.addElement("c");
v.addElement("b");
v.addElement("a");
System.out.println(v);
/*
* 遍历集合 方式 使用枚举遍历
* */
Enumeration en = v.elements();
while(en.hasMoreElements()){
System.out.println(en.nextElement());
}
}
Set
排序(升序) 按照自然顺序排序 ASCII码表的顺序排序
TreeSet集合 如何给自定义数据类型进行排序?
第一种方式====我是方法===========
让自定义类 实现 public interface Comparable<T>接口
此接口强行对实现它的每个类的对象进行整体排序。
这种排序被称为类的自然排序,
类的 compareTo 方法被称为它的自然比较方法。
/*
* 返回:负整数、零或正整数,根据此对象是小于、等于还是大于指定对象
* 此对象 小于 指定对象 返回 负整数
* 此对象 等于 指定对象 返回 0
* 此对象 大于 指定对象 返回正整数
* */========我是方法==============
public int compareTo(Object o) {
// 此对象 this 和 指定对象Object进行比较 按照年龄排序
/*
* 返回:负整数、零或正整数,根据此对象是小于、等于还是大于指定对象
* 此对象 小于 指定对象 返回 负整数
* 此对象 等于 指定对象 返回 0
* 此对象 大于 指定对象 返回正整数
* */
Teacher t = (Teacher)o;//向下转型
//System.out.println(this.getAge()+","+this.getName()+",,"+t.getAge()+".."+t.getName());
if(this.getAge() < t.getAge()){
return -1;
}
if(this.getAge() == t.getAge()){
//equals
//String 类的 compareTo方法
//如果参数字符串等于此字符串,则返回值 0;
//如果此字符串按字典顺序小于字符串参数,则返回一个小于 0 的值;
//如果此字符串按字典顺序大于字符串参数,则返回一个大于 0 的值。
return this.getName().compareTo(t.getName());
//return 0;
}
return 1;
第二种方式=======我是方法================
让容器具备比较性
在创建TreeSet集合的同时 传入public interface Comparator<T>接口
重写 compare方法
强行对某个对象 collection 进行整体排序 的比较函数。
/*
* 参数:
o1 - 要比较的第一个对象。
o2 - 要比较的第二个对象。
返回:
根据第一个参数小于、等于或大于第二个参数分别返回负整数、零或正整数。
第一个参数 小于 第二个参数 返回 负整数
第一个参数 等于 第二个参数 返回 0
第一个参数 大于 第二个参数 返回 正整数
=============我是方法=====================


遍历集合的常见方式,排序,用lambda表示是怎样的的更多相关文章
- Java Enum枚举 遍历判断 四种方式(包括 Lambda 表达式过滤)
示例代码如下: package com.miracle.luna.lambda; import java.util.Arrays; /** * @Author Miracle Luna * @Date ...
- java里遍历map的常见方式
public static void main(String[] args) { Map<String, String> map = new HashMap<String, Stri ...
- Java List集合 遍历 四种方式(包含 Lambda 表达式遍历)
示例代码如下: package com.miracle.luna.lambda; import java.util.ArrayList; import java.util.List; /** * @A ...
- Java Map集合 遍历 五种方式(包含 Lambda 表达式遍历)
示例代码如下: package com.miracle.luna.lambda; import java.util.HashMap; import java.util.Iterator; import ...
- Java Array数组 遍历 四种方式(包含 Lambda 表达式遍历)
示例代码如下: package com.miracle.luna.lambda; import java.util.Arrays; /** * @Author Miracle Luna * @Date ...
- java8的lambda过滤list遍历集合,排序
1.根据属性过滤list List<AllManagerBean> testLists = broadCastRoomMapper.allManagerlist(); List<Al ...
- Lambda表达式遍历集合
1.Collection Java 8 为Iterable接口新增了一个forEach(Consumer action)默认方法,该方法所需参数的类型是一个函数式接口,而Iterable接口是Coll ...
- Java forEach 方式遍历集合(Java 8 新特性)
JDK 8 新增 forEach 方式遍历集合,这种方式比原来的 for each 循环还要简洁和便利. 需要注意:如果你计算机安装的是 JDK 8 以前的版本,是不支持 JDK 8 的新特性 Lis ...
- 集合遍历数组三种常用方式(Collecton和Map)
Collection集合遍历数组的三种方式: 迭代器 foreach(增强for循环) JDK1.8之后的新技术Lambda 迭代器: 方法:public Iterator inerator():获取 ...
随机推荐
- appium使用相对坐标定位元素
最近在用appium做自动化时发现,有一些元素无法通过uiautomatorviewer进行定位,这样就只能通过相对坐标来进行定位了.但是,问题又来了:如何获取元素的坐标呢? 在网上找了半天也没找到相 ...
- hiho一下:Beautiful String
hiho一下:Beautiful String 记不清这是 hiho一下第几周的题目了,题目不难,不过对于练习编程,训练思维很有帮助.况且当时笔者处于学习算法的早期, 所以也希望刚接触算法的同学能多去 ...
- 海洋深处的数据中心——微软Natick项目
数据中心(data center)是云计算的支柱,云计算的蓬勃发展离不开数据中心在建造运营方面的不断创新.但云端数据中心的运行过程中会产生大量热量,冷却降温过程则意味着巨大的能源消耗,这意味着需要庞大 ...
- scss入门学习(一)
sass的文件后缀名 sass是目前流行的css预处理语言.sass有两种后缀文件,一种是.sass,不允许使用大括号和分号:另一种是.SCSS,允许使用大括号和分号,类似于我们平时写css的语法习惯 ...
- Spring-cloud微服务实战【十】:消息总线Bus
回忆一下,在上一篇文章中,我们使用了分布式配置中心config来管理所有微服务的配置文件,那这样有没有什么问题?有,那就是无法配置文件无法自动更新,当我的git服务器上的配置文件更新后,不能同步更 ...
- webpack的基本配置(初识)
webpack能根据模块的依赖关系递归地构建一个依赖关系图,当中包含了应用程序所需要的所有模块,最后打包成一个或多个bundle.它有四个核心概念entry.output .loader.plugin ...
- Python知识点汇总
*/ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:text.cpp * 作者:常轩 * 微信公众号:Worldhe ...
- Intellij IDEA 干货分享
更多视频详情:https://www.bilibili.com/video/av89385013/ Intellij IDEA 真是越用越强大 它总是在我们写代码的时候 不时给我们来个小惊喜 出于对 ...
- python xlwings Excel 内容截图
import xlwings as xw from PIL import ImageGrab def excel_save_img(path, sheet=0, img_name="1&qu ...
- 续python学习(一)
接上面没写完的知识点继写. 当然,这些知识点都很简单,可能没必要花费太多时间去记忆,多写写代码就会了. 5.字符串的使用.索引和切片是字符串主要的两个应用.索引:顾名思义就是找出某个字符在一个字符串中 ...