匿名内部类案例

匿名内部类访问方式

1.内部类可以直接访问外部内的成员 包括私有成员  

2.外部内要访问内部类成员或方法,必须要创建对象

 3.访问方式:外部类.内部类 对象名=外部类对象.内部类对象

案例一:

class OuterClass {
	private int num=10;
	class InnerClass{
	    public void show(){
		System.out.println(num);
	    }
	}
	public void method(){
		InnerClass iClass= new InnerClass();
		iClass.show();
	}
}
测试一:
class TestDemo{
    public static void main(String[] args) {
	OuterClass.InnerClass oi=new OuterClass().new InnerClass();
	oi.show();
    }
}

案例二:

class OuterClass2 {
	public int num=30;
	class InnerClass{
		public int num =20;
		public void show(){
			int num=10;
			System.out.println(num);//20
			System.out.println(this.num);//20
			System.out.println(OuterClass2.this.num);//30
		}
	}
	public static void main(String[] args) {
		OuterClass2.InnerClass ic = new OuterClass2().new InnerClass();
		ic.show();
	}
}

案例三:

class OuterClass3 {
	 public int num=30;
	 public void method() {
		 //局部内部类访问局部变量 局部变量必须是final的
	    final int num2=20;
	    class InnerClass{
	        private void show() {
		    System.out.println(num2);
	        }
	    }
	     InnerClass ic=new InnerClass();
	     ic.show();	
        } 
	 public static void main(String[] args) {
		 OuterClass3 oc = new OuterClass3();
		 oc.method();
	}
}


### Java中匿名内部类实现接口的方式 在Java中,匿名内部类可以通过实现接口的方式来完成特定功能。这种方式的核心在于,在定义匿名内部类的同时,也实现了该接口所规定的所有抽象方法。 以下是通过匿名内部类实现接口的具体方式: #### 使用场景 当需要快速创建一个仅需一次性使用的对象时,可以利用匿名内部类来简化代码结构[^1]。这种技术特别适用于那些只需要简单逻辑处理的情况,比如事件监听器或者线程运行体等。 #### 基本语法 匿名内部类的声明形式如下所示: ```java new 接口名称() { // 覆盖接口中的方法 } ``` 这里的关键点是`new 接口名称()`部分,表示正在基于某个已存在的接口创建一个新的匿名类实例,并立即对其进行初始化和使用[^2]。 #### 示例代码 下面是一个典型的例子,展示如何借助匿名内部类去实现`Runnable`接口的功能: ```java public class Main { public static void main(String[] args) { // 创建并启动一个新的线程 new Thread(new Runnable() { @Override public void run() { System.out.println("Hello from anonymous inner class!"); } }).start(); } } ``` 在这个案例里,我们并没有显式地命名这个新的`Runnable`实现类;而是直接在其被调用的位置上完成了整个类的设计与实例化过程[^3]。 对于更复杂的业务需求,则可能涉及到多个参数传递以及更加丰富的行为描述等情况下的应用模式。例如给定一个假想的服务提供者接口及其具体操作演示: ```java interface ServiceProvider{ String provideService(int param); } // 在实际运用处即时构建满足条件的对象实体 ServiceProvider sp=new ServiceProvider(){ @Override public String provideService(int param){ return "Provided service with parameter "+param; } }; System.out.println(sp.provideService(42)); ``` 上述片段展示了即使面对稍微复杂一点的任务也能轻松应对的情形下采用此类技巧的优势所在[^4]^. 需要注意的是,由于其本质属于局部变量范畴内的特殊类别成员关系特性决定了如果试图访问外部作用域里的非final/final-like(local variable captured by lambda expression must be final or effectively final rule applies here as well)类型的项目将会受到编译期错误提示约束影响[^5]. ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值