一般来说,有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

二.静态内部类

1.与类的其他成员相似,可以用static修饰内部类,这样的类称为静态内部类。

2.静态内部类与静态内部方法相似,只能访问外部类的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
  }
 }

5.运行结果:
  x=100
  y=Hello!

三.局部内部类:

在方法体或语句块(包括方法、构造方法、局部块或静态初始化块)内部定义的类成为局部内部类。
  局部内部类不能加任何访问修饰符,因为它只对局部块有效。
  1.局部内部类只在方法体中有效,就想定义的局部变量一样,在定义的方法体外不能创建局部内部类的对象
  2.在方法内部定义类时,应注意以下问题:
      a.方法定义局部内部类同方法定义局部变量一样,不能使用private、protected、public等访问修饰说明符修饰,也不能使用static修饰,但可以使用final和   abstract修饰
      b.方法中的内部类可以访问外部类成员。对于方法的参数和局部变量,必须有final修饰才可以访问。
      c.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

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

}

Java基础(54):java四种内部类详解(转)的更多相关文章

  1. Java解析XML的四种方法详解 - 转载

    XML现在已经成为一种通用的数据交换格式,平台的无关性使得很多场合都需要用到XML.本文将详细介绍用Java解析XML的四种方法 在做一般的XML数据交换过程中,我更乐意传递XML字符串,而不是格式化 ...

  2. java的四种内部类详解

    引言 内部类,嵌套在另一个类的里面,所以也称为:嵌套类; 内部类分为以下四种: 静态内部类 成员内部类 局部内部类 匿名内部类 一.静态内部类 静态内部类: 一般也称"静态嵌套类" ...

  3. 类与接口(二)java的四种内部类详解

    引言 内部类,嵌套在另一个类的里面,所以也称为 嵌套类; 内部类分为以下四种: 静态内部类 成员内部类 局部内部类 匿名内部类 一.静态内部类 静态内部类: 一般也称"静态嵌套类" ...

  4. Java线程同步的四种方式详解(建议收藏)

    ​ Java线程同步属于Java多线程与并发编程的核心点,需要重点掌握,下面我就来详解Java线程同步的4种主要的实现方式@mikechen 目录 什么是线程同步 线程同步的几种方式 1.使用sync ...

  5. java四种内部类详解

    一般来说,有4中内部类:常规内部类.静态内部类.局部内部类.匿名内部类. 一.常规内部类:常规内部类没有用static修饰且定义在在外部类类体中.   1.常规内部类中的方法可以直接使用外部类的实例变 ...

  6. [ 转载 ] Java开发中的23种设计模式详解(转)

    Java开发中的23种设计模式详解(转)   设计模式(Design Patterns) ——可复用面向对象软件的基础 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类 ...

  7. Java基础-反射(reflect)技术详解

    Java基础-反射(reflect)技术详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.类加载器 1>.JVM 类加载机制  如下图所示,JVM类加载机制分为五个部分 ...

  8. Java基础-变量的定义以及作用域详解

    Java基础-变量的定义以及作用域详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.字面量 常量(字面量)表示不能改变的数值(程序中直接出现的值).字面量有时也称为直接量,包 ...

  9. Java基础13:反射与注解详解

    Java基础13:反射与注解详解 什么是反射? 反射(Reflection)是Java 程序开发语言的特征之一,它允许运行中的 Java 程序获取自身的信息,并且可以操作类或对象的内部属性. Orac ...

随机推荐

  1. win7 创建软链接方式

    mklink  目标文件  源文件(需要被软链的文件) Win7中的软链接详解(mklink命令) Post by 铁木箱子 in 技术杂谈 on 2011-05-24 13:13. 点评一下 评论 ...

  2. day08

      软件系统体系结构   常见软件系统体系结构B/S.C/S 1.1 C/S C/S结构即客户端/服务器(Client/Server),例如QQ: 需要编写服务器端程序,以及客户端程序,例如我们安装的 ...

  3. 防止sql注入,过滤敏感关键字

    //sql过滤关键字 public static bool CheckKeyWord(string sWord) { //过滤关键字 string StrKeyWord = @"select ...

  4. C++ 简单中文敏感词检测工具类

    具体思路: 1->敏感词库,可从数据库读取,也可以从文件加载. 2->将敏感词转化为gbk编码,因为gbk严格按照字符一个字节,汉字两个字节的格式编码,便于容易切分文字段. 3->将 ...

  5. IOS应用程序生命周期的AppDelegate详解

    IOS 中的 AppDelegate.m/h 文件是很重要的呢,因为它是对 Application 的整个生命周期进行管理的. 先明白,每个iPhone应用程序都有一个UIApplication,UI ...

  6. Moogoose操作之Schema实现增删查改

    Schema不仅定义了文档结构和使用性能,可以为后面的Model和Entity提供公共的属性和方法. Schema.Model.Entity的关系: Schema : 可以定义字段类型,不具备数据库的 ...

  7. Bone Collector

    if(j>=w[i]) dp[i][j] = max(dp[i-1][j-w[i]]+v[i], dp[i-1][j]); else dp[i][j]=dp[i-1][j]; i 1 2 3 4 ...

  8. 史上最用心的iOS App上架流程【转】

    转:http://www.jianshu.com/p/16fa56eacb5e 题记 麻痹起来嗨!看网上那么多的教程,依然在我心爱的爱屁屁在上架的时候遇到各种 J8 问题,最大的问题就是:Xcode ...

  9. sell-- Calendar 和 Date- 01,月份不变年份+3或直接到2017

    1. 2016/11/24 import java.text.DateFormat; import java.text.SimpleDateFormat; import java.util.Calen ...

  10. Docker 简单入门

    Docker 简单入门 http://blog.csdn.net/samxx8/article/details/38946737