Java之内部类、匿名内部类、Lambda表达式和方法引用

简介: 1.内部类、2.匿名内部类、(重点掌握)3.Lambda表达式、4.方法引用


1.内部类

内部类顾名思义就是一个类里面再次定义一个类,这样做有好处也有坏处,好处是如果使用了内部类,那么这两个类之间的通信将会十分轻松。比如私有属性传递,但是缺点也很明显,就是内部类会导致类的结构复杂化。

内部类访问外部类私有化属性,方法的格式 与其实例化过程:

实例化过程

外部类.内部类  对象名称= new 外部类().内部类()

public class OuterClass {
    public class InnerClass {
        public void display() {
            System.out.println("This is the inner class.");
        }
    }
}
public class Example {
    public static void main(String[] args) {
        OuterClass.InnerClass obj = new OuterClass().new InnerClass();
        obj.display();
    }
}

image.gif

访问外部私有属性和方法等

str = 外部类.this.str

当实现static定义内部类时候,其访问外部类的属性方法的格式和实例化过程:

1.实例化过程

外部类.内部类 实例化对象名称 = new 外部类.内部类();

2.访问外部私有属性和方法

str = 外部类.str

public class OuterClass {
    private static int outerStaticField = 100;
    private int outerField = 200;
    public static class InnerClass {
        public void display() {
            System.out.println("Outer static field: " + outerStaticField);
        }
    }
    public static void outerStaticMethod() {
        System.out.println("Calling outer static method");
    }
}
public class Example {
    public static void main(String[] args) {
        OuterClass.InnerClass obj = new OuterClass.InnerClass();
        obj.display();
        OuterClass.outerStaticMethod();
    }
}

image.gif

注意:可以直接访问外部类的静态成员(包括静态属性和静态方法),但不能直接访问外部类的非静态成员(非静态属性和非静态方法)。

两者的区别:

1.当用static定义内部类时候,那么内部类其实就是一个独立的个体了所以可以不需要实例化其外部类就嗯呢更直接实例化内部类

除了内部类还可以有内部接口,接口内部实现抽象类,接口子类定义内部类

1.内部接口:

public class Example {
    interface InnerInterface {
        void display();
    }
    public static void main(String[] args) {
        InnerInterface innerObj = new InnerInterface() {
            public void display() {
                System.out.println("Inner interface implementation");
            }
        };
        innerObj.display();
    }
}

image.gif

2.接口内部实现抽象类

public interface OuterInterface {
    abstract class InnerAbstractClass {
        abstract void display();
    }
}
public class Example implements OuterInterface.InnerAbstractClass {
    public void display() {
        System.out.println("Implementation of inner abstract class");
    }
    public static void main(String[] args) {
        Example obj = new Example();
        obj.display();
    }
}

image.gif

3.接口子类定义内部类

interface OuterInterface {
    void outerMethod();
    class InnerClass {
        void innerMethod() {
            System.out.println("Inner class method");
        }
    }
}
class Example implements OuterInterface {
    public void outerMethod() {
        InnerClass innerObj = new InnerClass();
        innerObj.innerMethod();
    }
    public static void main(String[] args) {
        Example obj = new Example();
        obj.outerMethod();
    }
}

image.gif

4.方法种定义内部类

虽然一般内部类在类的哪里都可以进行定义,到那时,一般情况下,内部类都是定义在外部类的方法里面

public class OuterClass {
    public void outerMethod() {
        class InnerClass {
            void innerMethod() {
                System.out.println("Inner method");
            }
        }
        InnerClass innerObj = new InnerClass();
        innerObj.innerMethod();
    }
    public static void main(String[] args) {
        OuterClass obj = new OuterClass();
        obj.outerMethod();
    }
}

image.gif


2.匿名内部类

问题引出:由于一般情况下一个public类对应一个.java文件,那么如果类功能简单情况下,很多的类下就会产生大量的java类文件。所以通过匿名内部类可以不产生子类,就能完成子类带来的功能。

public class Main {
    public static void main(String[] args) {
        // 创建接口对象并调用方法
        MyInterface myInterface = new MyInterface() {
            @Override
            public void doSomething() {
                System.out.println("匿名内部类实现的方法");
            }
        };
        myInterface.doSomething(); // 输出:匿名内部类实现的方法
    }
}
// 定义接口
interface MyInterface {
    void doSomething();
}

image.gif


(重点掌握)3.Lambda表达式

匿名内部类由于其实现是比较复杂的,所以就诞生了Lambda表达式,这种表达式极大的简化的匿名内部类的操作

实现Lambda的语法有两种:

1.()->{方法体}

Runnable runnable = () -> {
    System.out.println("Hello, world!");
};

image.gif

2.()->语句

Calculator calculator = (a, b) -> a + b;

image.gif

@FunctionInterface注解

表示函数式接口,接口内只能出现一种抽象类方法

@FunctionalInterface
interface Calculator {
    int calculate(int a, int b);
}
public class LambdaExample {
    public static void main(String[] args) {
        Calculator add = (a, b) -> a + b;
        int result = add.calculate(10, 5);
        System.out.println("Addition result: " + result);
        Calculator subtract = (a, b) -> a - b;
        result = subtract.calculate(10, 5);
        System.out.println("Subtraction result: " + result);
    }
}

image.gif


4.方法引用

引用并不陌生,在以前的java的实例中就有着大量的引用,但是引用的大部分都是实例化对象,或者引用值,这里是对方法的引用。方法的引用分为三类:引用静态方法 引用某个对象的方法 引用特定类型的方法 引用构造方法

方法引用有以下四种:

引用静态方法 :                 类名称::static方法名称

@FunctionalInterface
interface Calculator {
public void caculate();
}
// 静态方法
class MathUtils {
    public static int multiply(int a, int b) {
        return a * b;
    }
}
// 方法引用
Calculator calculator = MathUtils::multiply;
int result = calculator.calculate(5, 3);
System.out.println("Multiplication result: " + result);

image.gif

引用某个对象的方法 :    实例化对象::普通方法

// 对象方法
class StringUtils {
    public int getLength(String str) {
        return str.length();
    }
}
// 方法引用
StringUtils stringUtils = new StringUtils();
Calculator calculator = stringUtils::getLength;
int result = calculator.calculate("Hello");
System.out.println("String length: " + result);

image.gif

引用特定类型的方法  :    特定类::普通方法

// 指定类型的方法
class StringUtils {
    public static boolean startsWith(String str, String prefix) {
        return str.startsWith(prefix);
    }
}
// 方法引用
BiPredicate<String, String> startsWith = StringUtils::startsWith;
boolean result = startsWith.test("Hello", "He");
System.out.println("Starts with 'He': " + result);

image.gif

引用构造方法:                   类名称::new

// 构造方法
class Person {
    private String name;
    public Person(String name) {
        this.name = name;
    }
    public String getName() {
        return name;
    }
}
// 方法引用
Function<String, Person> personFactory = Person::new;
Person person = personFactory.apply("John");
System.out.println("Person name: " + person.getName());

image.gif


目录
相关文章
|
28天前
|
Java
Java语言实现字母大小写转换的方法
Java提供了多种灵活的方法来处理字符串中的字母大小写转换。根据具体需求,可以选择适合的方法来实现。在大多数情况下,使用 String类或 Character类的方法已经足够。但是,在需要更复杂的逻辑或处理非常规字符集时,可以通过字符流或手动遍历字符串来实现更精细的控制。
194 18
|
1月前
|
Java 编译器 Go
【Java】(5)方法的概念、方法的调用、方法重载、构造方法的创建
Java方法是语句的集合,它们在一起执行一个功能。方法是解决一类问题的步骤的有序组合方法包含于类或对象中方法在程序中被创建,在其他地方被引用方法的优点使程序变得更简短而清晰。有利于程序维护。可以提高程序开发的效率。提高了代码的重用性。方法的名字的第一个单词应以小写字母作为开头,后面的单词则用大写字母开头写,不使用连接符。例如:addPerson。这种就属于驼峰写法下划线可能出现在 JUnit 测试方法名称中用以分隔名称的逻辑组件。
168 4
|
1月前
|
编解码 Java 开发者
Java String类的关键方法总结
以上总结了Java `String` 类最常见和重要功能性方法。每种操作都对应着日常编程任务,并且理解每种操作如何影响及处理 `Strings` 对于任何使用 Java 的开发者来说都至关重要。
214 5
|
2月前
|
算法 安全 Java
除了类,Java中的接口和方法也可以使用泛型吗?
除了类,Java中的接口和方法也可以使用泛型吗?
120 11
|
2月前
|
Java 开发者
Java 函数式编程全解析:静态方法引用、实例方法引用、特定类型方法引用与构造器引用实战教程
本文介绍Java 8函数式编程中的四种方法引用:静态、实例、特定类型及构造器引用,通过简洁示例演示其用法,帮助开发者提升代码可读性与简洁性。
|
3月前
|
Java 编译器 API
Java Lambda表达式与函数式编程入门
Lambda表达式是Java 8引入的重要特性,简化了函数式编程的实现方式。它通过简洁的语法替代传统的匿名内部类,使代码更清晰、易读。本文深入讲解Lambda表达式的基本语法、函数式接口、方法引用等核心概念,并结合集合操作、线程处理、事件回调等实战案例,帮助开发者掌握现代Java编程技巧。同时,还解析了面试中高频出现的相关问题,助你深入理解其原理与应用场景。
|
3月前
|
安全 Java API
Java中的Lambda表达式:简洁与功能的结合
Java中的Lambda表达式:简洁与功能的结合
396 211
|
3月前
|
安全 Java
Java中的Switch表达式:更简洁的多路分支
Java中的Switch表达式:更简洁的多路分支
472 211
|
3月前
|
算法 Java
Java语言实现链表反转的方法
这种反转方法不需要使用额外的存储空间,因此空间复杂度为,它只需要遍历一次链表,所以时间复杂度为,其中为链表的长度。这使得这种反转链表的方法既高效又实用。
326 0