java8特性,lambda表达式,简写的演变及应用

简介: 虽然可以使用Lambda表达式对某些接口进行简单的实现,但是并不是所有的接口都可以用Lambda表达式来实现,要求接口中定义的必须要实现的抽象方法==只能是一个==在JAVA8中 ,对接口加了一个新特性:default可以使用default对接口方法进行修饰,被修饰的方法在接口中可以默认实现
🍬 博主介绍
👨‍🎓 博主主页: chad_chang的主页
✨主攻领域:【大数据】【java】【python】【面试分析】

@[toc]

lambda表达式

1.1.简介

1.1.1.什么是Lambda?

Lambda是JAVA 8添加的新特性,说白了,Lambda是一个匿名函数

1.1.2.为什么使用Lambda

使用Lambda表达式可以对一个接口的方法进行非常简洁的实现

1.1.3.Lambda对接口的要求

虽然可以使用Lambda表达式对某些接口进行简单的实现,但是并不是所有的接口都可以用Lambda表达式来实现,要求接口中定义的必须要实现的抽象方法==只能是一个==
在JAVA8中 ,对接口加了一个新特性:default
可以使用default对接口方法进行修饰,被修饰的方法在接口中可以默认实现

1.1.4.@FunctionalInterface

修饰函数式接口的,接口中的抽象方法只有一个

1.2.基本语法

1.2.1.语法格式

(parameters) -> expression

(parameters) -> { statements; }
() 用来描述参数列表
{} 用来描述方法体 有时可以省略
-> lambda运算符

1.2.2.准备工作: 创建接口

/**
 * 无参数无返回值接口
 */
@FunctionalInterface
interface LambdaNoneReturnNoneParmeter {

    void test();
}

/**
 * 无返回值有单个参数
 */
@FunctionalInterface
interface LambdaNoneReturnSingleParmeter {

    void test(int n);
}

/**
 * 无返回值 多个参数的接口
 */
@FunctionalInterface
interface LambdaNoneReturnMutipleParmeter {

    void test(int a,int b);
}

/**
 * 有返回值 无参数接口
 */
@FunctionalInterface
interface LambdaSingleReturnNoneParmeter {

    int test();
}

/**
 * 有返回值 有单个参数的接口
 */
@FunctionalInterface
interface LambdaSingleReturnSingleParmeter {

    int test(int n);
}

/**
 * 有返回值 有多个参数的接口
 */
@FunctionalInterface
interface LambdaSingleReturnMutipleParmeter {

    int test(int a,int b);
}

1.2.3.创建类Demo

import org.junit.Test;

public class Demo {

    @Test
    public void test01() {

        LambdaSingleReturnMutipleParmeter lambda1 = new LambdaSingleReturnMutipleParmeter() {
            @Override
            public int test(int a, int b) {
                return a + b;
            }
        };

        int result = lambda1.test(1, 2);
        System.out.println(result);
    }
}

==注意==:运行,会出现以下错误
在这里插入图片描述
==解决方法==
修改工作空间
修改工作空间,路径为:.idea --> workspace.xml

找到标签 。在标签里加一行:

<property name="dynamic.classpath" value="true" />

如下图:
在这里插入图片描述
此刻可以顺利运行,但是这不是我们的重点;
重点是==lambda的学习==。

1.3语法精简

1.3.1. lambda写法

在这里插入图片描述
在Demo类中继续写以下代码:

    @Test
    public void test02(){
        LambdaSingleReturnMutipleParmeter lambda2 = (int a, int b) -> {
                return a + b;
        };

        int result2 = lambda2.test(1, 2);
        System.out.println(result2);
    }
}

1.3.2. 参数类型精简

因为在接口的方法中, 已经定义类参数的类型, 所以在lambda表达式中参数的类型可以省略
    @Test
    public void test02(){
        LambdaSingleReturnMutipleParmeter lambda2 = (a, b) -> {
                return a + b;
        };

        int result2 = lambda2.test(1, 2);
        System.out.println(result2);
    }
}

1.3.3. 参数小括号精简

如果参数列表中, 参数的个数只有==一个==, 此时小括号可以省略;

    @Test
    public void test03(){
    //一个参数一个返回值
        LambdaSingleReturnSingleParmeter lambda3 = a -> {return 10;};

        int result3 = lambda3.test(1);
        System.out.println(result3);
    }

1.3.4.方法大括号精简

如果方法中只有==一条语句==, 此时大括号也可以省略

1.3.5.大括号精简补充

如果方法体中唯一的一条语句是一个返回结果语句,
则省略大括号的同时 也必须省略return关键字

    @Test
    public void test04(){
    //无参一个返回值
        LambdaSingleReturnNoneParmeter lambda4 =()  -> 10;

        int result4 = lambda4.test();
        System.out.println(result4);
    }

1.4.语法进阶

1.4.1.方法引用(静态方法和普通方法)

1.4.1.1.why

在实际应用过程中, 一个接口在很多地方都会调用同一个实现, 例如

LambdaSingleReturnMutipleParmeter lambda1 = (a, b) -> a + b;
LambdaSingleReturnMutipleParmeter lambdab = (a, b) -> a * b;

这样一来每次都要写上具体的实现方法, 如果需求变更, 则每一处都需要更改, 基于这种情况, 可以将后续的实现更改为自定义的方法, 需要时直接调用即可.

1.4.1.2.what

方法引用:
可以快速的将一个lambda表达式的实现指向一个已经实现的方法
方法的隶属者 如果是静态方法, 隶属者就是一个类, 其他的话都是隶属对象
语法: ==方法的隶属者::方法名==
注意:

1 引用的方法中, 参数的个数和类型一定要和接口中定义的方法一致
2 返回值的类型也一定要和接口中的方法一致

1.4.1.3.how

1.4.1.3.1.静态方法
package stream.lambda.cn.itcast.b;

public class Demo {
    public static void main(String[] args) {
        // 精简前
        LambdaSingleReturnMutipleParmeter lambda1 = (a, b) -> a + b;
        LambdaSingleReturnMutipleParmeter lambda2 = (a, b) -> a * b;

        // 精简后
        LambdaSingleReturnMutipleParmeter lambda3 = (a, b) -> MyStaticClass.add(a, b);
        LambdaSingleReturnMutipleParmeter lambda4 = MyStaticClass::multiplication;
    }


}

// 静态方法类
class MyStaticClass {
    public static int add(int x, int y) {
        return x + y;
    }

    public static int multiplication(int x, int y) {
        return x * y;
    }
}


/**
 * 有返回值 有多个参数的接口
 */
@FunctionalInterface
interface LambdaSingleReturnMutipleParmeter {

    int test(int a, int b);
}
1.4.1.3.2.非静态普通方法
package stream.lambda.cn.itcast.c;

public class Demo {
    public static void main(String[] args) {
        // 精简前
        LambdaSingleReturnMutipleParmeter lambda1 = (a, b) -> a + b;
        LambdaSingleReturnMutipleParmeter lambda2 = (a, b) -> a * b;

        // 精简后
        MyNotStaticClass myNotStaticClassObj = new MyNotStaticClass();
        LambdaSingleReturnMutipleParmeter lambda3 = (a, b) -> myNotStaticClassObj.add(a, b);
        LambdaSingleReturnMutipleParmeter lambda4 = myNotStaticClassObj::multiplication;
        int result3 = lambda3.test(10, 20);
        int result4 = lambda4.test(10, 20);
        System.out.println("result3 = " + result3);
        System.out.println("result4 = " + result4);
    }
}

// 自定义非静态类
class MyNotStaticClass {
    public int add(int x, int y) {
        return x + y;
    }

    public int multiplication(int x, int y) {
        return x * y;
    }
}

/**
 * 有返回值 有多个参数的接口
 */
@FunctionalInterface
interface LambdaSingleReturnMutipleParmeter {
    int test(int a, int b);
}
目录
相关文章
|
3天前
|
Java 开发者
Java中的Lambda表达式:简化你的代码之旅
【8月更文挑战第17天】 在编程的海洋中,简洁是航行的风帆。Lambda表达式,作为Java 8的一大亮点,为开发者提供了一种更为紧凑、易读的编码方式。本篇文章将带你领略Lambda表达式的魅力,从基础概念到实际应用,让你的代码像诗句一样流畅。
13 4
|
1天前
|
安全 前端开发 Java
随着企业应用复杂度提升,Java Spring框架以其强大与灵活特性简化开发流程,成为构建高效、可维护应用的理想选择
随着企业应用复杂度提升,Java Spring框架以其强大与灵活特性简化开发流程,成为构建高效、可维护应用的理想选择。依赖注入使对象管理交由Spring容器处理,实现低耦合高内聚;AOP则分离横切关注点如事务管理,增强代码模块化。Spring还提供MVC、Data、Security等模块满足多样需求,并通过Spring Boot简化配置与部署,加速微服务架构构建。掌握这些核心概念与工具,开发者能更从容应对挑战,打造卓越应用。
6 1
|
1天前
|
安全 Java 测试技术
深入探讨Java安全编程的最佳实践,帮助开发者保障应用的安全性
在网络安全日益重要的今天,确保Java应用的安全性成为了开发者必须面对的课题。本文介绍Java安全编程的最佳实践,包括利用FindBugs等工具进行代码审查、严格验证用户输入以防攻击、运用输出编码避免XSS等漏洞、实施访问控制确保授权访问、采用加密技术保护敏感数据等。此外,还强调了使用最新Java版本、遵循最小权限原则及定期安全测试的重要性。通过这些实践,开发者能有效提升Java应用的安全防护水平。
5 1
|
4天前
|
存储 设计模式 Java
Java中的if-else语句:深入解析与应用实践
Java中的if-else语句:深入解析与应用实践
|
1天前
|
Java 程序员
"Java程序员必备秘籍:Lambda表达式如何让你的代码瘦身90%?揭秘简化编程的终极奥秘!"
【8月更文挑战第19天】Java持续进化,Lambda表达式自Java 8起赋予其新活力。它简化代码,使编程更愉悦。以前,简单功能需冗长代码,如列表排序要用匿名内部类实现`Comparator`。现在一行Lambda足矣。Lambda如`(参数) -&gt; {表达式}`,支持零或多参数。
|
Java Unix 数据库管理
java定时框架:表达式设置
Quartz中时间表达式的设置-----corn表达式 (注:这是让我看比较明白的一个博文,但是抱歉,没有找到原作者,如有侵犯,请告知)   时间格式: ,   分别对应: 秒>分>小时>日>月>周>年,  举例: 1.
858 0
|
7天前
|
Java 开发者
奇迹时刻!探索 Java 多线程的奇幻之旅:Thread 类和 Runnable 接口的惊人对决
【8月更文挑战第13天】Java的多线程特性能显著提升程序性能与响应性。本文通过示例代码详细解析了两种核心实现方式:Thread类与Runnable接口。Thread类适用于简单场景,直接定义线程行为;Runnable接口则更适合复杂的项目结构,尤其在需要继承其他类时,能保持代码的清晰与模块化。理解两者差异有助于开发者在实际应用中做出合理选择,构建高效稳定的多线程程序。
28 7
|
6天前
|
安全 Java 数据库
一天十道Java面试题----第四天(线程池复用的原理------>spring事务的实现方式原理以及隔离级别)
这篇文章是关于Java面试题的笔记,涵盖了线程池复用原理、Spring框架基础、AOP和IOC概念、Bean生命周期和作用域、单例Bean的线程安全性、Spring中使用的设计模式、以及Spring事务的实现方式和隔离级别等知识点。
|
6天前
|
存储 监控 安全
一天十道Java面试题----第三天(对线程安全的理解------>线程池中阻塞队列的作用)
这篇文章是Java面试第三天的笔记,讨论了线程安全、Thread与Runnable的区别、守护线程、ThreadLocal原理及内存泄漏问题、并发并行串行的概念、并发三大特性、线程池的使用原因和解释、线程池处理流程,以及线程池中阻塞队列的作用和设计考虑。
|
1天前
|
Java
java开启线程的四种方法
这篇文章介绍了Java中开启线程的四种方法,包括继承Thread类、实现Runnable接口、实现Callable接口和创建线程池,每种方法都提供了代码实现和测试结果。
java开启线程的四种方法