JAVA8中Predicate,Consumer,UnaryOperator,Function接口的应用
笔者平时时间有限,直接贴代码,关于几个接口的差别,可以查看这两篇文章
感受lambda之美,推荐收藏,需要时查阅
https://juejin.im/post/5ce66801e51d455d850d3a4a
Java8 函数式编程读书总结
https://juejin.im/entry/5912bbe0a0bb9f0058b485d6
<T> List<T> readList(Table table, OID[] oids, String[] fieldNames, Class clazz, List<T> defaultValue, Predicate<? super T> filter, Consumer<? super List<T>> consumer, UnaryOperator<? super T> operator);
@Override
public <T> List<T> readList(Table table, OID[] oids, String[] fieldNames, Class clazz, List<T> defaultValue, Predicate<? super T> filter, Consumer<? super List<T>> consumer, UnaryOperator<? super T> operator) {
if (table == null || table.isEmpty()) {
return defaultValue;
} Class[] declaredFieldType = getDeclaredFieldType(fieldNames, clazz); if(ArrayUtils.isEmpty(fieldNames)||ArrayUtils.isEmpty(declaredFieldType))
{
log.error("字段名长度和字段数据类型长度不能为null");
throw new IllegalArgumentException("字段名长度和字段数据类型长度不能为null");
} if(!ArrayUtils.isSameLength(fieldNames, declaredFieldType))
{
throw new IllegalArgumentException("字段名个数与字段数据类型数组长度不一致");
} Map<OID, Table.Row> rowMapping = table.getMap(); if(MapUtils.isEmpty(rowMapping)) {
return defaultValue;
} log.debug("待查询oid名称:{}",String.join(",", fieldNames)); String [] oidInDottedString = Arrays.asList(oids).stream().map(OID::toDottedString).toArray(size->new String[size]); List<T> list = new LinkedList<T>(); for(Table.Row row : rowMapping.values()) { Set<OID> keys = row.getMap().keySet(); try {
T instance = (T)clazz.newInstance(); for (OID key : keys) {
String dotString = key.toDottedString(); for (int i = 0; i < oidInDottedString.length; i++) { String oidString = oidInDottedString[i]; if (dotString.contains(oidString)) { String fieldName = fieldNames[i]; Variable value = row.getVariable(key); Class declaredType = declaredFieldType[i]; setProperty(instance,declaredType,fieldName,value); }
}
} list.add(instance); }catch (IllegalAccessException|InstantiationException e)
{
log.error("提取属性失败:{}",e);
}
} if(operator != null && CollectionUtils.isNotEmpty(list)) {
list.stream().forEach(instance->{operator.apply(instance);});
} if(filter != null && CollectionUtils.isNotEmpty(list)) {
list = list.stream().filter(filter).collect(Collectors.toList());
} if(consumer != null && CollectionUtils.isNotEmpty(list)) {
consumer.accept(list);
} return list;
}
<T> T readObject(Table table, String[] fieldNames, Class clazz, T defaultValue,final Predicate<? super T> filter,final Consumer<? super T> consumer,final UnaryOperator<? super T> operator); @Override
public <T> T readObject(Table table, String[] fieldNames, Class clazz, T defaultValue, Predicate<? super T> filter, Consumer<? super T> consumer, UnaryOperator<? super T> operator) { if (table == null || table.isEmpty()) {
return defaultValue;
}
Optional<T> result = readList(table, fieldNames, clazz, Arrays.asList(defaultValue)/*, null, null, null*/).stream().findFirst(); return handleSingleObject(result,filter,consumer,operator);
用法:(方法签名会有出入,没有的签名方法,通过重载实现了,在此不贴出来代码,看官可自行实现,有疑问可跟帖留意交流)
//读取ip地址、子网掩码
Table ipAddrTable = snmpHelper.getTable(MIB.IpAddrTable); List<SnmpIfCard> ifCards = agentService.readList(ipAddrTable,
agentService.translateOID(SnmpObjectNotation.ipAddrEntry),
SnmpObjectNotation.ipFieldNames, SnmpIfCard.class,
null,
(SnmpIfCard ifCard) -> {
if(ifCard!=null) {
//过滤掉回环地址
String ifIpAddr = ifCard.getIfIpAddr();
return !"127.0.0.1".equals(ifIpAddr);
}
return false;
},(SnmpIfCard ifCard)->{
if(ifCard != null) {
//设置nodeId
ifCard.setNodeId(nodeId);
return ifCard;
}
return null;
}); //网口流量
Table ifTable = snmpHelper.getTable(MIB.IfTable);
agentService.readList(ifTable,SnmpObjectNotation.trafficFieldNames,SnmpIfCardTraffic.class,
null,
(SnmpIfCardTraffic traffic)->{
if(traffic != null) {
Integer ifIndex = traffic.getIfIndex();
//如果网口索引里没有这个IfIndex,则不采集(通常是过滤IfIndex =1的本地回环网卡 lo)
List<Integer> allIfIndex = ifCards.stream().map(SnmpIfCard::getIfIndex).collect(Collectors.toList());
return allIfIndex.contains(ifIndex);
}
return false;
},
captured::setTraffics,
(SnmpIfCardTraffic traffic)->{
if(traffic != null) {
//通过网口索引匹配,将对应网口索引的子网掩码和ip地址拷贝到网口流量信息实体上面
Optional<SnmpIfCard> matched = matchIfCard(ifCards, traffic);
if (matched.isPresent()) {
traffic.setNodeId(nodeId);
traffic.setIfIpNetMask(matched.get().getIfIpNetMask());
traffic.setIfIpAddr(matched.get().getIfIpAddr());
}
return traffic;
}
return null;
}); //文件系统使用情况
Table hrStorageEntry = snmpHelper.getTable(MIB.hrStorageEntry); agentService.readList(hrStorageEntry, SnmpObjectNotation.hrStorageEntryFields,
SnmpFileSystemUsage.class,null,
captured::setFsUsage,
(SnmpFileSystemUsage usage)->{
if(usage != null) {
usage.setNodeId(nodeId);
return usage;
}
return null;
});
//内存使用率
Table memory = snmpHelper.getTable(MIB.memory);
agentService.readObject(memory, SnmpObjectNotation.memoryFieldNames, SnmpMemoryUsage.class,
(SnmpMemoryUsage) null,
captured::setMemoryUsage,
(usage) -> {
if(usage !=null) {
usage.setNodeId(nodeId);
return usage;
}
return null;
}); //系统运行状态,从这里获取cpu使用率信息
Table sysStats = snmpHelper.getTable(MIB.systemStats);
agentService.readObject(sysStats, SnmpObjectNotation.systemStatFields, SnmpCPUUsage.class,
(SnmpCPUUsage)null,
captured::setCpuUsage,
(usage) -> {
if(usage !=null) {
usage.setNodeId(nodeId);
return usage;
}
return null;
});
Function的应用
<R,T> List<R> readTable(Table table, String[] fieldNames, Class clazz, Class[] declaredFieldType, List<T> defaultValue,
Predicate<? super T> filter, Consumer<? super List<T>> consumer, Function<? super T, ? extends R> mapper); @Override
public <R,T> List<R> readTable(Table table, String[] fieldNames, Class clazz, Class[] declaredFieldType, List<T> defaultValue,
Predicate<? super T> filter, Consumer<? super List<T>> consumer, Function<? super T, ? extends R> mapper)
{
List<T> list = readList(table, fieldNames, clazz, declaredFieldType, defaultValue, filter, consumer);
return list.stream().map(item -> {
R target = mapper.apply(item);
return target;
}).collect(Collectors.toList());
} @Override
public <T> List<T> readList(Table table, String[] fieldNames, Class clazz, Class[] declaredFieldType, List<T> defaultValue, Predicate<? super T> filter, Consumer<? super List<T>> consumer) {
return readList(table,fieldNames,clazz,declaredFieldType,defaultValue,filter,consumer,null);
}
JAVA8中Predicate,Consumer,UnaryOperator,Function接口的应用的更多相关文章
- java8中规范的四大函数式接口
java8中规范的四大函数式接口: 1.Consumer<T> :消费型接口 void accept(T t); 2.Supplier<T> :供给型接口 ...
- [六] 函数式接口的复合方法示例 predicate 谓词逻辑运算 Function接口 组合运算 比较器 逆序 比较链
复合的方法 有些函数式接口提供了允许复合的方法 也就是可以将Lambda表达式复合成为一个更加复杂的方法 之前的章节中有说到: 接口中的compose, andThen, and, or, negat ...
- 乐字节-Java8核心特性实战之函数式接口
什么时候可以使用Lambda?通常Lambda表达式是用在函数式接口上使用的.从Java8开始引入了函数式接口,其说明比较简单:函数式接口(Functional Interface)就是一个有且仅有一 ...
- Java8新特性第2章(接口默认方法)
在Java中一个接口一旦发布就已经被定型,除非我们能够一次性的更新所有该接口的实现,否者在接口的添加新方法将会破坏现有接口的实现.默认方法就是为了解决这一问题的,这样接口在发布之后依然能够继续演化. ...
- Java8常用的内置函数式接口(一)Predicate、Consumer、Supplier、Function
Java8常用的内置函数式接口(一) 简介 JDK 1.8 API中包含了很多内置的函数式接口.有些是在以前版本的Java中大家耳熟能详的,例如Comparator接口,或者Runnable接口.对这 ...
- Function接口 – Java8中java.util.function包下的函数式接口
Introduction to Functional Interfaces – A concept recreated in Java 8 Any java developer around the ...
- Spring8中lambda表达式的学习(Function接口、BiFunction接口、Consumer接口)
代码重构,为了确保功能的等效性,梳理代码时,发现如下代码: public SingleRespTTO fundI(SingleReqTTO request) throws Exception { re ...
- java基础---->java8中的函数式接口
这里面简单的讲一下java8中的函数式接口,Function.Consumer.Predicate和Supplier. 函数式接口例子 一.Function:接受参数,有返回参数 package co ...
- Java8新特性:Function接口和Lambda表达式参考
Lambda基本:https://blog.csdn.net/wargon/article/details/80656575 https://www.cnblogs.com/hyyq/p/742566 ...
随机推荐
- sql like 拼接字符串模糊查询
这种分割的值大家常用,如果要用like 来查询包含2,这个值的数据有哪些,这个怎么查? like '%2%' ????,这是不行的如果是 44,125,687 同样可以查出来,那么就想到通配符, l ...
- 小程序UI设计(8)-布局分解-FlexBox的align-content应用
FlexBox的align-content到底是什么鬼,我也搞了好半天才开发出来,目前工具中WViewRow组件使用了此属性,WViewColumn中此属性不起作用.下图是justify-conten ...
- 广告域名审核之后跳转技术:点击域名A页面iframe框架下的链接,域名A跳转到域名B
广告域名审核之后跳转技术:点击域名A页面iframe框架下的链接,域名A跳转到域名B注:域名B为afish.cnblogs.com 域名A页面代码:<!DOCTYPE html PUBLIC & ...
- uoj30【CF Round #278】Tourists(圆方树+树链剖分+可删除堆)
- 学习了一波圆方树 学习了一波点分治 学习了一波可删除堆(巧用 ? STL) 传送门: Icefox_zhx 注意看代码看怎么构建圆方树的. tips:tips:tips:圆方树内存记得开两倍 CO ...
- Liquibase使用(转)
文章目录 介绍快速使用Springboot中引入依赖配置日志文件ChangeLog编写变更记录ChangeSetMaven中引入依赖配置liquibase.properties编写变更记录Change ...
- EF 批量添加数据
原文:https://www.cnblogs.com/liuruitao/p/10049191.html 原文:https://www.cnblogs.com/yaopengfei/p/7751545 ...
- Linux下nc或scp命令来实现文件传输
很实用的小技巧, 可以使用nc或者是scp nc命令,转载自:https://www.cnblogs.com/xuybin/archive/2013/09/27/3343098.html 发送端:ca ...
- maven打断点报错
- Hibernate 5 Maven 仓库的 Artifacts
Hibernate artifacts 官方发布的仓库在 JBoss Maven repository 中.Hibernate 发布的 artifacts 也会同时同步到 Maven Central ...
- 征途堆积出友情的永恒「堆优化dp」
直接写题解: 很简单的dp暴力转移式子:f[i]=MAX{f[j]+max(tax[j],sum[i]-sum[j])} 观察式子,只有一个变量sum[i]; 而其他都为定量; 则考虑维护 两个定量: ...