笔者平时时间有限,直接贴代码,关于几个接口的差别,可以查看这两篇文章

感受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接口的应用的更多相关文章

  1. java8中规范的四大函数式接口

    java8中规范的四大函数式接口: 1.Consumer<T>   :消费型接口    void accept(T t); 2.Supplier<T>      :供给型接口  ...

  2. [六] 函数式接口的复合方法示例 predicate 谓词逻辑运算 Function接口 组合运算 比较器 逆序 比较链

    复合的方法 有些函数式接口提供了允许复合的方法 也就是可以将Lambda表达式复合成为一个更加复杂的方法 之前的章节中有说到: 接口中的compose, andThen, and, or, negat ...

  3. 乐字节-Java8核心特性实战之函数式接口

    什么时候可以使用Lambda?通常Lambda表达式是用在函数式接口上使用的.从Java8开始引入了函数式接口,其说明比较简单:函数式接口(Functional Interface)就是一个有且仅有一 ...

  4. Java8新特性第2章(接口默认方法)

    在Java中一个接口一旦发布就已经被定型,除非我们能够一次性的更新所有该接口的实现,否者在接口的添加新方法将会破坏现有接口的实现.默认方法就是为了解决这一问题的,这样接口在发布之后依然能够继续演化. ...

  5. Java8常用的内置函数式接口(一)Predicate、Consumer、Supplier、Function

    Java8常用的内置函数式接口(一) 简介 JDK 1.8 API中包含了很多内置的函数式接口.有些是在以前版本的Java中大家耳熟能详的,例如Comparator接口,或者Runnable接口.对这 ...

  6. Function接口 – Java8中java.util.function包下的函数式接口

    Introduction to Functional Interfaces – A concept recreated in Java 8 Any java developer around the ...

  7. Spring8中lambda表达式的学习(Function接口、BiFunction接口、Consumer接口)

    代码重构,为了确保功能的等效性,梳理代码时,发现如下代码: public SingleRespTTO fundI(SingleReqTTO request) throws Exception { re ...

  8. java基础---->java8中的函数式接口

    这里面简单的讲一下java8中的函数式接口,Function.Consumer.Predicate和Supplier. 函数式接口例子 一.Function:接受参数,有返回参数 package co ...

  9. Java8新特性:Function接口和Lambda表达式参考

    Lambda基本:https://blog.csdn.net/wargon/article/details/80656575 https://www.cnblogs.com/hyyq/p/742566 ...

随机推荐

  1. 如何在国内跑Kubernetes的minikube

    跑minikube start老是被卡住,得到如以下的结果 minikube start --registry-mirror=https://registry.docker-cn.com miniku ...

  2. 数据管理必看!Kendo UI for jQuery过滤器状态保持

    Kendo UI for jQuery最新试用版下载 Kendo UI目前最新提供Kendo UI for jQuery.Kendo UI for Angular.Kendo UI Support f ...

  3. TXNLP 09-17

    上节课讲了一些算法的复杂度,都比较简单,我就没有单独截图.1 n n^2 nlogn logn...等等 其实一些排序问题也比较简单.还是给大家列举一下. 归并排序: 主定理定理..吐血 算法复杂度相 ...

  4. mongodb添加索引

    mongodb可以添加多列索引 稠密索引:该列中即使有null值也能给你查出来 稀疏索引:该列中查不出包含null值的列 二叉树索引是由码放的顺序的,哈希则是散列,相邻的数字,排列顺序并不一定紧邻

  5. [python](Docker SDK)上传镜像到私有仓库(tls、身份认证)

    (Docker SDK)上传镜像到私有仓库(tls.身份认证) API:https://docker-py.readthedocs.io/en/stable/ 环境:python:3.7.3 配置参数 ...

  6. Nowcoder的JS计时器题分析

    题目描述 实现一个打点计时器,要求1.从 start 到 end(包含 start 和 end),每隔 100 毫秒 console.log 一个数字,每次数字增幅为 12.返回的对象中需要包含一个 ...

  7. HZOJ 20190727 T2 单(树上dp+乱搞?+乱推式子?+dfs?)

    考试T2,考试时想到了40pts解法,即对于求b数组,随便瞎搞一下就oxxk,求a的话,很明显的高斯消元,但考试时不会打+没开double挂成10pts(我真sb),感觉考试策略还是不够成熟,而且感觉 ...

  8. mysql8.0.11安装

    1.下载mysql-->下载 2.解压 3.添加my.ini配置文件 [mysqld]# 设置3306端口port=3306# 设置mysql的安装目录basedir=C:\wnmp\mysql ...

  9. MySQL_(Java)使用JDBC向数据库发起查询请求

    MySQL_(Java)使用JDBC向数据库发起查询请求 传送门 MySQL_(Java)使用JDBC创建用户名和密码校验查询方法 传送门 MySQL_(Java)使用preparestatement ...

  10. 如何卸载zabbix且删除

    1.彻底卸载zabbix和删除残留文件 1 2   [root@localhost etc]# service zabbix stop   //这个命令是停止服务 [root@localhost et ...