当前位置: 首页 > news >正文

java 内部类

一般来说,有4中内部类:常规内部类、静态内部类、局部内部类、匿名内部类。

 一.常规内部类:常规内部类没有用static修饰且定义在在外部类类体中。
  1.常规内部类中的方法可以直接使用外部类的实例变量和实例方法。
  2.在常规内部类中可以直接用内部类创建对象
  3.代码如下:
 public class MyOuter {
 private int x = 100;

 // 创建内部类
 class MyInner {
  private String y = "Hello!";

  public void innerMethod() {
   System.out.println("内部类中 String =" + y);
   System.out.println("外部类中的x =" + x);// 直接访问外部类中的实例变量x
   outerMethod();

   System.out.println("x is" + MyOuter.this.x);
  }

 }

 public void outerMethod() {
  x++;

 }

 public void makeInner() {
//在外部类方法中创建内部类实例
  MyInner in = new MyInner();
 }

 /**
  * @param args
  */
 public static void main(String[] args) {

  MyOuter mo = new MyOuter();
  // 使用外部类构造方法创建mo对象
  MyOuter.MyInner inner = mo.new MyInner();//常规内部类需要通过外部类的实例才能创建对象,与实例变量需要通过对象来访问相似
  // 创建inner对象
  inner.innerMethod();
  // TODO Auto-generated method stub

 }

}
  4.运行结果:
  
                                内部类中 String =Hello!
    外部类中的x =100
    x is101

 二.静态内部类:与类的其他成员相似,可以用static修饰内部类,这样的类称为静态内部类。静态内部类与静态内部方法相似,只能访问外部类的static成员,不能直接访问外部类的实例变量,与实例方法,只有通过对象引用才能访问。
  3.由于static内部类不具有任何对外部类实例的引用,因此static内部类中不能使用this关键字来访问外部类中的实例成员,但是可以访问外部类中的static成员。这与一般类的static方法想通
  4.实例代码:
 package com.m.ou;

public class MyOuter {
 public static int x=100;
 public static class MyInner{
  private String y="Hello!";
  public void innerMethod(){
   System.out.println("x="+x);
   System.out.println("y="+y);
   
   
   
  }
  
  
 }

 /**
  * @param args
  */
 public static void main(String[] args) {
  MyOuter.MyInner si=new MyOuter.MyInner();//静态内部类不通过外部实例就可以创建对象;与类变量可以通过类名访问相似
  si.innerMethod();
  // TODO Auto-generated method stub

 }

}
  4.运行结果:
  x=100
  y=Hello!
 三.局部内部类:在方法体或语句块(包括方法、构造方法、局部块或静态初始化块)内部定义的类成为局部内部类。
  局部内部类不能加任何访问修饰符,因为它只对局部块有效。
  1.局部内部类只在方法体中有效,就想定义的局部变量一样,在定义的方法体外不能创建局部内部类的对象
  2.在方法内部定义类时,应注意以下问题:
   1.方法定义局部内部类同方法定义局部变量一样,不能使用private、protected、public等访问修饰说明符修饰,也不能使用static修饰,但可以使用final和   abstract修饰
   2.方法中的内部类可以访问外部类成员。对于方法的参数和局部变量,必须有final修饰才可以访问。
   3.static方法中定义的内部类可以访问外部类定义的static成员
  3.程序代码:
 public class Jubu {
 private int size=5,y=7;
 public Object makeInner(int localVar){
  final int finalLocalVar=localVar;
  //创建内部类,该类只在makeInner()方法有效,就像局部变量一样。在方法体外部不能创建MyInner类的对象
  class MyInner{
   int y=4;
   public String toString(){
    return "OuterSize:"+size+
        "\nfinalLocalVar"+" "+"this.y="+this.y;
    
    
   }
   
  }
  
  
  
  return new MyInner();
  
  
  
 }
}

class Main{ /**
  * @param args
  */
 public static void main(String[] args) {
  
  Object obj=new Jubu().makeInner(47);//创建Jubu对象obj,并调用它的makeInner()方法,该方法返回一个
  //该方法返回一个MyInner类型的的对象obj,然后调用其同toString方法。
  System.out.println(obj.toString());
  // TODO Auto-generated method stub

 }


}  
  4.运行结果:
  
  OuterSize:5
  finalLocalVar this.y=4
 四.匿名内部类:定义类的最终目的是创建一个类的实例,但是如果某个类的实例只是用一次,则可以将类的定义与类的创建,放到与一起完成,或者说在定义类的同时就创建一个类
  以这种方法定义的没有名字的类成为匿名内部类。
   声明和构造匿名内部类的一般格式如下:
   new ClassOrInterfaceName(){

    /*类体*/ }

   1.匿名内部类可以继承一个类或实现一个接口,这里的ClassOrInterfaceName是匿名内部类所继承的类名或实现的接口名。但匿名内部类不能同时实现一个接口和继承一个类,也不能实现多个接口。如果实现了一个接口,该类是Object类的直接子类,匿名类继承一个类或实现一个接口,不需要extends和implements关键字。
  
   2.由于匿名内部类没有名称,所以类体中不能定义构造方法,由于不知道类名也不能使用关键字来创建该类的实例。实际上匿名内部类的定义、构造、和第一次使用都发生在同样一个地方。此外,上式是一个表达式,返回的是一个对象的引用,所以可以直接使用或将其复制给一个对象变量。例:


   TypeName obj=new Name(){

   /*此处为类体*/
      }
  同样,也可以将构造的对象作为调用的参数。例:
   
   someMethod(new Name(){
   /*此处为类体*/  });
   3.程序代码:
  public class NiMing {
 private int size=5;
 public Object makeInner(int localVar){
  final int finalLocalVar=localVar;
  return new Object(){
   //使用匿名内部类
   public String toString(){
    return "OuterSize="+size+"\nfinalLocalVar="+finalLocalVar;
    
    
   }
   
   
  };
  
  
 }

 /**
  * @param args
  */
public static void main(String args[])
 {
 Object obj=new NiMing().makeInner(47);
 System.out.println(obj.toString());
 
 
 
 }

}
 4.程序运行结果:
   OuterSize=5
   finalLocalVar=47

 

 from:http://blog.csdn.net/qq435757399/article/details/7037007

转载于:https://www.cnblogs.com/interfacehwx/p/5400949.html

相关文章:

  • 经典算法研究系列:七、深入浅出遗传算法,透析GA本质
  • [Android] Upload package to device fails #2720
  • 15分钟引发的思考
  • 【JUC】JDK1.8源码分析之CyclicBarrier(四)
  • 在Tomcat中理解Servlet的运行机理
  • Collections.sort()
  • 更新-解决linux oracle shell上下箭调用历史命令
  • robotframework笔记19
  • 科学家提出记忆形成新解 大脑玩的拼图游戏
  • Spring Boot文档阅读
  • 网站性能提高实战经验点滴记录
  • Effective C++学习笔记 chapter 1
  • ipmi对于统一硬件管理的意义
  • 微信JS-SDK应用DEMO
  • Javascript 页面刷新
  • [ JavaScript ] 数据结构与算法 —— 链表
  • 【面试系列】之二:关于js原型
  • 【知识碎片】第三方登录弹窗效果
  • AzureCon上微软宣布了哪些容器相关的重磅消息
  • const let
  • java第三方包学习之lombok
  • JDK 6和JDK 7中的substring()方法
  • js 实现textarea输入字数提示
  • Sequelize 中文文档 v4 - Getting started - 入门
  • Theano - 导数
  • UEditor初始化失败(实例已存在,但视图未渲染出来,单页化)
  • 开年巨制!千人千面回放技术让你“看到”Flutter用户侧问题
  • 聊聊directory traversal attack
  • 面试题:给你个id,去拿到name,多叉树遍历
  • 什么软件可以提取视频中的音频制作成手机铃声
  • 要让cordova项目适配iphoneX + ios11.4,总共要几步?三步
  • 原生 js 实现移动端 Touch 滑动反弹
  • 最近的计划
  • ​七周四次课(5月9日)iptables filter表案例、iptables nat表应用
  • (4)Elastix图像配准:3D图像
  • (6)添加vue-cookie
  • (Matalb分类预测)GA-BP遗传算法优化BP神经网络的多维分类预测
  • (TipsTricks)用客户端模板精简JavaScript代码
  • (剑指Offer)面试题41:和为s的连续正数序列
  • (七)理解angular中的module和injector,即依赖注入
  • (四)模仿学习-完成后台管理页面查询
  • (五)c52学习之旅-静态数码管
  • (原創) 如何解决make kernel时『clock skew detected』的warning? (OS) (Linux)
  • 、写入Shellcode到注册表上线
  • .NET Framework .NET Core与 .NET 的区别
  • .NET 应用架构指导 V2 学习笔记(一) 软件架构的关键原则
  • .net 怎么循环得到数组里的值_关于js数组
  • .NET6 命令行启动及发布单个Exe文件
  • ??如何把JavaScript脚本中的参数传到java代码段中
  • @GlobalLock注解作用与原理解析
  • [ 攻防演练演示篇 ] 利用通达OA 文件上传漏洞上传webshell获取主机权限
  • [2024最新教程]地表最强AGI:Claude 3注册账号/登录账号/访问方法,小白教程包教包会
  • [30期] 我的学习方法
  • [ActionScript][AS3]小小笔记
  • [ARC066F]Contest with Drinks Hard