匿名内部类 / lambda 表达式

java中的匿名内部类总结

匿名内部类也就是没有名字的内部类

正因为没有名字,所以匿名内部类只能使用一次,它通常用来简化代码编写

但使用匿名内部类还有个前提条件:必须继承一个父类或实现一个接口

实例1:不使用匿名内部类来实现抽象方法

1

2

3

4

5

6

扫描二维码关注公众号,回复: 9131359 查看本文章

7

8

9

10

11

12

13

14

15

16

abstract class Person {

    public abstract void eat();

}

class Child extends Person {

    public void eat() {

        System.out.println("eat something");

    }

}

public class Demo {

    public static void main(String[] args) {

        Person p = new Child();

        p.eat();

    }

}

运行结果:eat something

可以看到,我们用Child继承了Person类,然后实现了Child的一个实例,将其向上转型为Person类的引用

但是,如果此处的Child类只使用一次,那么将其编写为独立的一个类岂不是很麻烦?

这个时候就引入了匿名内部类

实例2:匿名内部类的基本实现

1

2

3

4

5

6

7

8

9

10

11

12

13

14

abstract class Person {

    public abstract void eat();

}

public class Demo {

    public static void main(String[] args) {

        Person p = new Person() {

            public void eat() {

                System.out.println("eat something");

            }

        };

        p.eat();

    }

}

运行结果:eat something

可以看到,我们直接将抽象类Person中的方法在大括号中实现了

这样便可以省略一个类的书写

并且,匿名内部类还能用于接口上

实例3:在接口上使用匿名内部类

interface Person {

    public void eat();

}

public class Demo {

    public static void main(String[] args) {

        Person p = new Person() {

            public void eat() {

                System.out.println("eat something");

            }

        };

        p.eat();

    }

}

运行结果:eat something

由上面的例子可以看出,只要一个类是抽象的或是一个接口,那么其子类中的方法都可以使用匿名内部类来实现

最常用的情况就是在多线程的实现上,因为要实现多线程必须继承Thread类或是继承Runnable接口

实例4:Thread类的匿名内部类实现

public class Demo {

    public static void main(String[] args) {

        Thread t = new Thread() {

            public void run() {

                for (int i = 1; i <= 5; i++) {

                    System.out.print(i + " ");

                }

            }

        };

        t.start();

    }

}

运行结果:1 2 3 4 5

实例5:Runnable接口的匿名内部类实现

1

2

3

4

5

6

7

8

9

10

11

12

13

public class Demo {

    public static void main(String[] args) {

        Runnable r = new Runnable() {

            public void run() {

                for (int i = 1; i <= 5; i++) {

                    System.out.print(i + " ");

                }

            }

        };

        Thread t = new Thread(r);

        t.start();

    }

}

运行结果:1 2 3 4 5

******************************************************

lambda表达式 

*  Lambda 表达式 简化线程(用一次)的使用
*  Lamda表达式  只适合接口 有一个方法的时候   如果是俩个方法 就会出问题
package com.thread;

/**
 *  Lambda 表达式 简化线程(用一次)的使用
 *  Lamda表达式  只适合接口 有一个方法的时候   如果是俩个方法 就会出问题
 */
public class LambdaThread {



    //静态内部类 内部类的好处  如果外部类不访问 就不会被加载 节省资源
    static class Test implements  Runnable{

        @Override
        public void run() {
            for (int i = 0; i <20; i++) {
                System.out.println("一边听歌");
            }
        }
    }

    public static void main(String[] args) {
        //最初的方法
        //new Thread(new Test()).start();
        //局部内部类
        class Test2 implements Runnable{
            public void run() {
                for(int i=0;i<20;i++) {
                    System.out.println("一边听歌");
                }
            }
        }
        new Thread(new Test2()).start(); //写的还是不太方便

        //匿名内部类   必须借助接口或者父类
        //如果是接口 必须实现方法 不然会报错
        new Thread(new Runnable() {
            @Override
            public void run() {
                for (int i = 0; i < 20; i++) {
                    System.out.println("一般听哦");
                }
            }
        }).start();   //也是不太方便

        //jdk8 简化  lambda表达式  只有简单的类或 接口才会使用lambda表达式 目的是为了简化操作
        //  接口里面 只有一个方法的可以推到出来 要是俩个的话 就无法识别了
       new Thread(()->{
           for (int i = 0; i < 20; i++) {
               System.out.println("我是lambda 表达式  哈哈哈");
           }
       }).start();
    }
}
发布了19 篇原创文章 · 获赞 8 · 访问量 4131

猜你喜欢

转载自blog.csdn.net/paohui001lqp/article/details/100994686