java 匿名内部类

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

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

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

 

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

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();

    }

}


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

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

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

 

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

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();

    }

}

可以看到,我们直接将抽象类Person中的方法在大括号中实现了运行结果:eat something

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

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

 

实例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接口的匿名内部类实现

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

 

以下是一个测试以及记录:

 

package com.jvm;

import java.util.ArrayList;
import java.util.Comparator;
import java.util.List;

/**
 * 
 * @author chain
 * 
 * (1) compareTo的两个对象不能是基本数据格式
 * 
 * (2) 在jdk1.8下匿名内部类的写法必须重写接口所有的抽象方法,系统创建的实现类不会自动创建所有抽象方法.
 * 
 * (3)Comparator接口有两个抽象方法,一个是compare,另一个是equals方法,但是他的equals就可以不用进行重写,这是因为:
 * 	所有类默认继承Object,所以该类已有了Object的equals方法,相当于重写了equals方法。
 *
 */
public class anonymousClass {

	public static void main(String[] args) {
		List<student> list  = new ArrayList<student>();
		list.add(new student(10,"wanger"));
		list.add(new student(10,"wanger"));
		
		list.sort(new Comparator<student>() {

			@Override
			public int compare(student o1, student o2) {
				// TODO Auto-generated method stub
				return o1.getNum().compareTo(o2.getNum());
			}
			
		});
		
		method1(new MyInterface() {
			
			@Override
			public void test2() {
				// TODO Auto-generated method stub
				System.out.println("test2");
			}
			
			@Override
			public int test1() {
				// TODO Auto-generated method stub
				return 0;
			}
		});
	}
	
	public static void method1(MyInterface myInterface) {
		System.out.println("to do myInteface");
	}
}



 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值