java Stream流常见操作方法(反射,类加载器,类加载,反射)
作者:??pofenx???? 发布时间:2022-03-24 06:54:56
Stream流常见的中间操作方法
Streamfilter(Predicate predicate):用于对流中的数据进行过滤
predicate接口中的方法 boolean test(T t):对给定的参数进行判断,返回一个布尔值
Stream limit(long maxSize):返回此流中元素组成的流,截取前指定参数个数的数据
Stream skip(long n) :跳过指定参数个数据,返回有该流的剩余元素组成的流
staticStreamconcat(Stream a ,Stream b):合并a和b两个流为一个流
Streamdiatinct():返回有该留的不同元素(根据Objectequals(Object) 组成的流
Stream sorted():返回有潮流的元素组成的流,根据自然顺序排序
Stream sorted(Comparator comparator):返回由该流元素组成的流,根据提供的Compatator进行排序
Streammap(Function mapper):返回由给定函数应用于此流的元素结果组成的流
function 接口中的方法 R applu(T t)
intStream mapToint(TointFunction mapper):返回一个intStream其中包含将给定函数应用于此流的元素的结果
intStream: 表示原始int流
ToIntFunction接口中的方法
int applyAsInt(T value)
package Demo1;
import java.util.ArrayList;
public class Demo32 {
public static void main(String[] args) {
ArrayList<String> list = new ArrayList<String>();
list.add("林青霞");
list.add("张曼玉");
list.add("王祖贤");
list.add("柳岩");
list.add("张敏");
list.add("张无忌");
//以张开头
list.stream().filter(s -> s.startsWith("张")).forEach(System.out::println);
System.out.println("-------------");
//长度为3
list.stream().filter(s -> s.length()==3).forEach(System.out::println);
System.out.println("---------------");
//张,长度为3
list.stream().filter(s -> s.startsWith("张")).filter(s -> s.length()==3).forEach(System.out::println);
}
}
package Demo1;
import java.util.ArrayList;
public class Demo33 {
public static void main(String[] args) {
ArrayList<String> list = new ArrayList<String>();
list.add("林青霞");
list.add("张曼玉");
list.add("王祖贤");
list.add("柳岩");
list.add("张敏");
list.add("张无忌");
//需求一,取前三个数据在控制台输出
list.stream().limit(3).forEach(System.out::println);
//跳过前三个元素
list.stream().skip(3).forEach(System.out::println);
//跳过前2个元素,把剩下元素中国前两个在控制台上输出
list.stream().skip(2).limit(2).forEach(System.out::println);
}
}
package Demo1;
import java.util.ArrayList;
import java.util.stream.Stream;
public class Demo34 {
public static void main(String[] args) {
ArrayList<String> list = new ArrayList<String>();
list.add("林青霞");
list.add("张曼玉");
list.add("王祖贤");
list.add("柳岩");
list.add("张敏");
list.add("张无忌");
//需求1,取前4给数据组成一个流
Stream<String> s1 = list.stream().limit(4);
//跳过前两个数据组成一个流
Stream<String> s2 = list.stream().skip(2);
//需求3,合并1,2得到的流,结果输出在控制台
Stream.concat(s1,s2).forEach(System.out::println);
//4,合并1,2流,输出在控制台,字符串元素不能重复
Stream.concat(s1,s2).distinct().forEach(System.out::println);
}
}
package Demo1;
import java.util.ArrayList;
import java.util.stream.Stream;
public class Demo34 {
public static void main(String[] args) {
ArrayList<String> list = new ArrayList<String>();
list.add("lingqinxia");
list.add("zhangmanyu");
list.add("wangzhuxian");
list.add("liuyan");
list.add("zhangming");
list.add("zhangwuji");
//按照字母顺序输出
// list.stream().sorted().forEach(System.out::println);
//按照长度排列输出
//list.stream().sorted((s1,s2) -> s1.length() - s2.length()).forEach(System.out::println);
list.stream().sorted((s1,s2) ->{
int num = s1.length()-s2.length();
int num2 = num ==0?s1.compareTo(s2):num;
return num2;
}).forEach(System.out::println);
}
}
package Demo1;
import java.util.ArrayList;
import java.util.stream.Stream;
public class Demo34 {
public static void main(String[] args) {
ArrayList<String> list = new ArrayList<String>();
list.add("30");
list.add("40");
list.add("50");
list.add("7");
list.add("87");
list.add("756");
//将集合中的制度串数据转换为整数输出
//list.stream().map(Integer::parseInt).forEach(System.out::println);
// list.stream().mapToInt(Integer::parseInt).forEach(System.out::println);
//int sum 返回流中的总和
int result = list.stream().mapToInt(Integer::parseInt).sum();
System.out.println(result);
}
}
Stream流中常见的终结操作方法
void forEach(Consumer action):对此流的每个元素操作
Consumer接口中的方法
void accept(T t ):对给定的参数执行此操作
long count():返回此流中的元素数
package Demo1;
import java.util.ArrayList;
import java.util.stream.Stream;
public class Demo34 {
public static void main(String[] args) {
ArrayList<String> list = new ArrayList<String>();
list.add("林青霞");
list.add("张曼玉");
list.add("王祖贤");
list.add("柳岩");
list.add("张敏");
list.add("张无忌");
//list.stream().forEach(System.out::println);
long count = list.stream().filter(s -> s.startsWith("张")).count();
System.out.println(count);
}
}
反射
类加载器
类加载:
当程序要使用某个类时,如果该类还未被加载到内存中,则系统会通过类的加载,类的连接,类的初始化三个步骤对类进行初始化,JVM将会连续完成这三个步骤,所有有时也罢这三个步骤统称为类加载或者类初始化
类的加载:
就是指将class文件读入内存。并为之创建一个java.lang.class对象
任何类被使用时。系统都会为之建立一个java.lang.class对象
类的连接:
验证阶段:用于检验被加载的类时候具有正确的内部结构,并和其他类协调一致
准备阶段:负责为类的类变量分配内存,并设置默认初始化值
解析阶段:将类的二进制数据中的符号引用替换为直接引用
类的初始化:
在该阶段,主要就是对类变量进行初始化
类的初始化步骤:
假如类还未被类加载器和连接,则程序先加载并连接该类
加入该类的直接父类还未被初始化,则先初始化其直接父类
加入类中有初始化语句,则系统会依次执行这些初始化语句
注意:在执行第二个步骤的时候,系统对字节父类的初始化步骤也遵循初始化步骤1-3
类的初始化时机:
创建类的实例
调用类的类方法
访问类或者接口类变量,或者为该类变量赋值
使用反射方式来强制创建某个类或者接口对应的java.lang.class对象
初始化某个类的子类
直接使用java.exe命令来运行某个主类
反射概述
java反射机制:是指在运行时去获取一个类的变量和方法的信息,然后通过获取到的信息来创建对象,调用方法的一种机制。由于这种动态性,可以极大的增强程序的灵活性,程序不用在编译期就完成确定,在运行时仍然可以扩展
获取class类的对象
使用class属性来获取对应的class对象,举例:student.class将会返回student类对应的class对象
调用对象的getclass()方法,返回该对象所属类对应的class对象,该方法是object类中的方法,所有的java对象都可以调用该方法
使用class类中的静态方法forName(String className),该方法需要传入字符串参数,该字符串参数的值是某个类的全路径,也就是完整的包名路径
来源:https://juejin.cn/post/7114557304619401229
猜你喜欢
- 在源码的阅读过程中,可以了解别人实现某个功能的涉及思路,看看他们是怎么想,怎么做的。接下来,我们看看这篇Java源码解析之object的详细
- java和javascript长得是如此地相像,那么它们是一回事儿吗?现在让我来揭晓答案吧!JavaScript 是一种嵌入式脚本文件,直接
- IDEA安装后找不到.vmoptions文件在安装IDEA后在C盘的C:\Users\你的电脑用户名.IntelliJIdea2019.1\
- 项目背景我们开发过程中会碰到这样一类问题,就是数据层或三方接口返回的Bean对象需要转换重新装换一下我们需要的对象。我们通常的做法就是通过g
- 用户提出一个需求:当修改产品价格的时候,需要记录操作日志,什么时候做了什么事情。想必这个案例,只要是做过应用系统的小伙伴们,都应该遇到过吧?
- 线程池execute与submit区别在使用线程池的时候,看到execute()与submit()方法。都可以使用线程池执行一个任务,但是两
- 各个方法1. 得到class的成员变量首先得到object的class对象然后在class对象中用getDeclaredFields()方法
- 一个发送验证码的需求:包括限制文本框输入长度和只允许输入数字按惯例 先上图:class MyBody extends StatefulWid
- 前言入职新公司到现在也有一个月了,完成了手头的工作,前几天终于有时间研究下公司旧项目的代码。在研究代码的过程中,发现项目里用到了Spring
- 1. Spring ProfileSpring可使用Profile绝对程序在不同环境下执行情况,包含配置、加载Bean、依赖等。 Sprin
- 问题:Information:java: Errors occurred while compiling module &lsquo
- 本文实例为大家分享了Java打印指定年月日历的具体代码,供大家参考,具体内容如下日历如下:程序如下://打印指定年月的日历public cl
- IntelliJ IDEA中实现跟eclipse一样的outline方法,查看文件内所有已经声明的方法。mac的可以在key map 里搜索
- @GetMapping和@GetMapping(value=““)区别背景初期对于@GetMappi
- 目录1.搭建环境2.项目搭建3.配置maven4.项目结构5.配置 MapperScan 注解6.创建实体7.创建接口8.测试8.1 upd
- 说明:曾经在网上看过花样繁多的分页,很多都号称如何通用,但很多时候往往不尽如人意:有在分页类中还加入URL地址信息的,有在分页类中还进行分页
- 什么是继承面向对象的特征:封装:不必要公开的数据成员和方法,使用private关键字进行修饰。意义:安全性。背景代码中创建的类, 主要是为了
- autoMapping和autoMappingBehavior的区别autoMappingBehaviormybatis核心配置文件中set
- Java连接SQL Server数据库的详细操作流程一.明确JDK版本和下载驱动1.1 JDK版本查看win + r输入cmd,命令窗口输入
- 先来了解一下什么是XMLType类型。XMLType是Oracle从9i开始特有的数据类型,是一个继承了Blob的强大存在,可以用来存储xm