[Java基础]函数式接口

在这里插入图片描述

代码如下:

package MyInterfacePack01;@FunctionalInterface
public interface MyInterface {void show();
}
package MyInterfacePack01;public class MyInterfaceDemo {public static void main(String[] args){MyInterface my= ()->System.out.println("hello world");my.show();}}

在这里插入图片描述

代码如下:

package MyInterfacePack01;public class RunnableDemo {public static void main(String[] args){startThread(new Runnable() {@Overridepublic void run() {System.out.println(Thread.currentThread().getName()+"线程启动了");}});startThread(()->System.out.println(Thread.currentThread().getName()+"线程启动了"));}private static void startThread(Runnable r){new Thread(r).start();}}

在这里插入图片描述

代码如下:

package MyInterfacePack01;import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;public class ComparatorDemo {public static void main(String[] args){ArrayList<String> array = new ArrayList<String>();array.add("hello");array.add("javaaaaa");array.add("world");System.out.println("排序前"+array);Collections.sort(array,getComparator());System.out.println("排序后"+array);}private static Comparator<String> getComparator(){
//        Comparator<String> comp = new Comparator<String>() {
//            @Override
//            public int compare(String s1, String s2) {
//                return s1.length()-s2.length();
//            }
//        };
//        return comp;return (s1,s2)->s1.length()-s2.length();}
}

在这里插入图片描述
在这里插入图片描述

代码如下:

package SupplierPack;import java.util.function.Supplier;public class SupplierDemo {public static void main(String[] args){String s = getString(()->{return "Tom";});String s1 = getString(()->"TOM");System.out.println(s);System.out.println(s1);Integer i = getInteger(()->30);System.out.println(i);}private static String getString(Supplier<String> sup){return sup.get();}private static Integer getInteger(Supplier<Integer> sup){return sup.get();}}

在这里插入图片描述

代码如下:

package SupplierPack;import java.util.function.Supplier;public class SupplierTest {public static void main(String[] args){int [] arr = {19,50,28,37,64};int maxValue =  getMax(()->{int max = arr[0];for (int i = 1;i<arr.length;i++){if (arr[i] > max){max = arr[i];}}return max;});System.out.println(maxValue);}private static int getMax(Supplier<Integer> sup){return sup.get();}}

在这里插入图片描述

代码如下:

package SupplierPack;import java.util.function.Consumer;public class ConsumerDemo {public static void main(String[] args){
//        operatorString("Tom",(String s)->{
//            System.out.println(s);
//        });operatorString("Tom",s->System.out.println(s));operatorString("Tom",System.out::println);operatorString("Tom",s->System.out.println(new StringBuilder(s).reverse().toString()));System.out.println("------------------------------------------");operatorString("Jack",s->System.out.println(s),s->System.out.println(new StringBuilder(s).reverse().toString()));}private static void operatorString(String name,Consumer<String> con1,Consumer<String> con2){
//        con1.accept(name);
//        con2.accept(name);con1.andThen(con2).accept(name);}private static void operatorString(String name, Consumer<String> con){con.accept(name);}}

在这里插入图片描述

代码如下:

package SupplierPack;import java.util.function.Consumer;public class ConsumerTest {public static void main(String[] args){String[] strArray = {"Tom,20","Jack,23","Bom,18"};printInfo(strArray,(String str)->{String name = str.split(",")[0];System.out.print("姓名"+name);},(String str)->{int age = Integer.parseInt(str.split(",")[1]);System.out.println(",年龄"+age);});}public static void printInfo(String[] strArray, Consumer<String> con1,Consumer<String> con2){for (String str:strArray){con1.andThen(con2).accept(str);}}}

在这里插入图片描述

代码如下:

package SupplierPack;import java.util.function.Predicate;public class PredicateDemo01 {public static void main(String[] args){boolean b1 = checkString("hello",(String s)->{return s.length() > 8;});boolean b2 = checkString("hello",s->s.length() > 8);boolean b3 = checkString("helloworld",s->s.length() > 8);System.out.println(b1);System.out.println(b2);System.out.println(b3);}private static boolean checkString(String s, Predicate<String> pre){
//        return pre.test(s);return pre.negate().test(s);}}
package PredicatePack01;import java.io.StringReader;
import java.util.function.Predicate;public class PredicateDemo01 {public static void main(String[] args){boolean b1 = checkString("hello",s->s.length() > 8);System.out.println(b1);boolean b2 = checkString("helloworld",s->s.length()> 8);System.out.println(b2);boolean b3 = checkString("hello",s->s.length() > 8 ,s->s.length()<15);System.out.println(b3);boolean b4 = checkString("helloworld",s->s.length() > 8 , s->s.length() < 15);System.out.println(b4);}private static boolean checkString(String s, Predicate<String> pre1,Predicate<String> pre2){
//        boolean b1 = pre1.test(s);
//        boolean b2 = pre2.test(s);
//        boolean b = b1 && b2;
//        return b;
//        return pre1.and(pre2).test(s);return pre1.or(pre2).test(s);}private static boolean checkString(String s, Predicate<String> pre){return pre.test(s);}}

在这里插入图片描述

代码如下:

package PredicatePack01;import java.util.ArrayList;
import java.util.function.Predicate;public class PredicatePack {public static void main(String[] args){String[] strArray = {"Tom,30","Jack,34","Bom,49","Lily,34","Mike,33"};ArrayList<String> array = myFilter(strArray,s->s.split(",")[0].length()>2,s->Integer.parseInt(s.split(",")[1]) > 33);for (String str:array){System.out.println(str);}}private static ArrayList<String> myFilter(String[] strArray, Predicate<String> pre1,Predicate<String> pre2){ArrayList<String> array = new ArrayList<String>();for (String str:strArray){if(pre1.and(pre2).test(str))array.add(str);}return array;}
}

在这里插入图片描述

代码如下:

package PredicatePack01;import java.util.function.Function;public class FunctionDemo {public static void main(String[] args){
//        convert("100",(String s)->{
//            return Integer.parseInt(s);
//        });convert("100",s->Integer.parseInt(s));convert("100",Integer::parseInt);convert(100,i->String.valueOf(i+566));convert("100",s->Integer.parseInt(s),i->String.valueOf(i+566));}private static void convert(String s,Function<String,Integer> fun1,Function<Integer,String > fun2){
//        Integer i = fun1.apply(s);
//        String ss  = fun2.apply(i);
//        System.out.println(ss);String ss = fun1.andThen(fun2).apply(s);System.out.println(ss);}private static void convert(int i,Function<Integer,String> fun){String s = fun.apply(i);System.out.println(s);}private static void convert(String s, Function<String,Integer> fun){Integer i  = fun.apply(s);System.out.println(i);}}

在这里插入图片描述

代码如下:

package PredicatePack01;import java.util.function.Function;public class FunctionTest {public static void main(String[] args){String s = "Tom,35";convert(s,(String ss)->{return ss.split(",")[1];},(String ss)->{return Integer.parseInt(ss);},(Integer i)->{return i+70;});convert(s,ss->ss.split(",")[1],ss->Integer.parseInt(ss),i->i+70);convert(s,ss->ss.split(",")[1],Integer::parseInt,i->i+70);}private static void convert(String s, Function<String,String> fun1,Function<String,Integer> fun2,Function<Integer,Integer> fun3){Integer i = fun1.andThen(fun2).andThen(fun3).apply(s);System.out.println(i);}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/310172.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql单库用户隔离_Mysql数据库隔离级别

数据库事务四大特性(ACID)原子性(Atomicity)原子性是指事务中的操作要么全部成功&#xff0c;要么失败回滚。一致性(Consistency)一致性是指事务必须使数据库从一个一致性状态变换到另一个一致性状态&#xff0c;也就是说一个事务执行之前和执行之后都必须处于一致性状态。拿转…

Tree Cutting POJ - 2378(树形DP)

题意&#xff1a;有n个谷仓有n-1条路连接&#xff0c;问最少删除哪几个点才能使得删除点后得到的连通图的加点数不大于n/2. 分析&#xff1a;求树的重心的变形题&#xff0c;poj3107的简单版&#xff0c;一遍dfs从叶子到根转移找出找到以每个节点为根的子树的结点数&#xff0…

从零搭建分布式文件系统MinIO比FastDFS要更合适

前两天跟大家分享了一篇关于如何利用FastDFS组件来自建分布式文件系统的文章&#xff0c;有兴趣的朋友可以阅读下《用asp.net core结合fastdfs打造分布式文件存储系统》。通过留言发现大家虽然感兴趣&#xff0c;但是都觉得部署比较麻烦。的确&#xff0c;fastdfs的部署很繁琐&…

ember.js mysql_用AWS部署ember.jspadrino应用系列之一

aws提供了一年免费试用服务。这里&#xff0c;记录下&#xff0c;配置aws和部署开源cms程序——维卡币操盘手的整个过程。主要内容包括&#xff1a;EC2实例的创建和设置——ruby环境和nginx配置&#xff0c;部署ruby应用。RDS实例的创建和使用——mysql数据库参数组的使用。S3库…

[Java基础]方法引用

代码如下: package PrintablePack;public interface Printable {void printString(String s);}package PrintablePack;public class PrintableDemo {public static void main(String[] args){usePrintable(s-> System.out.println(s));usePrintable(System.out::println);/…

Maximum Sum UVA - 108(连续子序列最大和—变形之子矩阵最大和)

题目大意&#xff1a;给出 n*n 的矩阵&#xff0c;找每隔数字之和最大的子矩阵&#xff0c;输出最大和。 解题思路&#xff1a;枚举矩阵左上和右下的坐标&#xff0c;分别合并子矩阵的每列&#xff0c;使得二维转化为一维&#xff0c;然后利用连续子序列最大和去做就行。 Tim…

甲方爸爸,大概你要的是代码生成器吧?

作者&#xff1a;邹溪源&#xff0c;长沙资深互联网从业者&#xff0c;架构师社区特邀嘉宾&#xff01;一1&#xff09;有一天&#xff0c;我的朋友Y童鞋分享了他正在做的一个内部开源项目&#xff0c;这个开源项目从外表上看&#xff0c;跟目前市场上那些代码生成器本没有特别…

使用pdf.js来预览pdf文件_适用于Dynamics365与PowerApps的注释预览组件

powerapps/dynamics365适用的注释预览/批量下载组件自定义组件为预览功能原生预览支持的文件类型:图像,zip,音频,pdf支持批量打包注释为zip下载到本地使用浏览器预览支持:音频,视频,图像,pdf,文本,xml,json等,理论上只需要浏览器支持打开的文件类型,均可预览使用方法:1.导入解决…

[PAT乙级]1001 害死人不偿命的(3n+1)猜想

卡拉兹(Callatz)猜想&#xff1a; 对任何一个正整数 n&#xff0c;如果它是偶数&#xff0c;那么把它砍掉一半&#xff1b;如果它是奇数&#xff0c;那么把 (3n1) 砍掉一半。这样一直反复砍下去&#xff0c;最后一定在某一步得到 n1。卡拉兹在 1950 年的世界数学家大会上公布了…

Sticks UVA - 307(切木棍 线性区间dp,线性dp,区间思想。)

题目大意&#xff1a;将n节木棒接成m个长度相等的木条&#xff0c;要求木条的长度尽可能的短 Time limit 3000 ms OS Linux George took sticks of the same length and cut them randomly until all parts became at most 50 units long. Now he wants to return st…

消息队列,我只选RabbitMQ!

高并发架构是架构师的必修课&#xff0c;而消息队列&#xff0c;则是王冠上最闪亮的那颗明珠&#xff01;能否驾驭消息队列这款高并发神器&#xff0c;亦成为架构师的试金石。作为专注.NET领域十多年的老架构师&#xff0c;下面从队列本质、技术选型、实战应用三个方面&#xf…

python比较三个数_python经典练习题(三)

人生苦短&#xff0c;你需要python继续学习python第一题题目&#xff1a;输入三个整数 x,y,z&#xff0c;请把这三个数由小到大输出不借助sortnum1 int(input("请输入第一个数"))num2 int(input("请输入第二个数"))num3 int(input("请输入第三个数&qu…

[PAT乙级]1002 写出这个数

读入一个正整数 n&#xff0c;计算其各位数字之和&#xff0c;用汉语拼音写出和的每一位数字。 输入格式&#xff1a; 每个测试输入包含 1 个测试用例&#xff0c;即给出自然数 n 的值。这里保证 n 小于 10​100​​。 输出格式&#xff1a; 在一行内输出 n 的各位数字之和的…

ROADS POJ - 1724(限制条件的最短路)【邻接表+深搜】

思路&#xff1a;先说下题意&#xff0c;题意第一行给了一个k,代表你有k的钱数&#xff0c;下一行有一个n,代表n个点&#xff0c;然后一个m&#xff0c;代表m条边&#xff0c;然后接下来m行,每行有四个数&#xff0c;分别代表起点、终点、路径长度和要花费的钱数&#xff0c;题…

使用Jexus 容器化您的 Blazor 应用程序

在本文中&#xff0c;我们将介绍如何将 Blazor 应用程序放入Jexus 容器以进行开发和部署。我们将使用 .NET Core CLI&#xff0c;因此无论平台如何&#xff0c;使用的命令都将是相同的。Blazor 托管模型Blazor 有两个托管模型&#xff0c;它们的要求不同&#xff0c;本文主要基…

mysql中临时修改参数用什么关键字_postgresql 中的参数查看和修改方式

1.查看参数文件的位置使用show 命令查看,比较常用的show config_file.此还可以查看pg_settings数据字典.test# show config_file;config_file------------------------------/data/pgdata/postgresql.conf(1 row)test# show hba_filetest-# ;hba_file-------------------------…

[PAT乙级]1004 成绩排名

读入 n&#xff08;>0&#xff09;名学生的姓名、学号、成绩&#xff0c;分别输出成绩最高和成绩最低学生的姓名和学号。 输入格式&#xff1a; 每个测试输入包含 1 个测试用例&#xff0c;格式为 第 1 行&#xff1a;正整数 n 第 2 行&#xff1a;第 1 个学生的姓名 学号…

圆桌会议 HDU - 1214(规律+模拟队列)

Time limit 1000 ms Memory limit 32768 kB OS Windows Source 杭电ACM省赛集训队选拔赛之热身赛 HDU ACM集训队的队员在暑假集训时经常要讨论自己在做题中遇到的问题.每当面临自己解决不了的问题时,他们就会围坐在一张圆形的桌子旁进行交流,经过大家的讨论…

【A】 Natasha3.0 引擎亮给你,请你来折腾

文章转载授权级别&#xff1a;A一 、 引言Natasha 距离上个 2. 版本大概有1个月了&#xff0c;在4月份里我把模板与引擎进行了重构&#xff0c;旨在更抽象、规范、合理&#xff0c;方便其他人参与开源、定制。接下来我将从 引擎的结构 、类库的使用及新热的 Source Generators …

linux ps mysql_linux系统中ps指令使用详解

在linux系统作为和unix和ubuntu相同的系统&#xff0c;ps指令经常被用到查看程序进程的状态&#xff0c;但是这个指令具体怎么用您会吗&#xff1f;本文就以centos为例&#xff0c;结合项目中服务器的实际应用&#xff0c;给大家讲解下ps指令的用法。一、参数a——显示现行终端…