内部类含义:

在Java中允许一个类的定义位于另一个类的内部,前者称为内部类,后者称为外部类。

Inner class 一般用在定义它的类或语句块之内,在外部引用它时必须给出完整的名称。

Inner class的名字不能与包含它的外部类的类名相同。

创建内部类对象:

外部类名.内部类名变量名= new外部类名() .new内部类名();

创建静态内部类对象:

外部类名.内部类名变量名= new外部类名.内部类名();

成员内部类:

(static成员内部类和非static成员内部类)

成员内部类作为类成员用法:

1.和外部类不同,Inner class还可以声明为private或protected。

2.可以调用外部类的结构。

3.Inner class可以声明为static的,但此时就不能再使用外层类的

非static的成员变量。

成员内部类作为类用法:

1.可以在内部定义属性、方法、构造器等结构。

2.可以声明为abstract类,因此可以被其它的内部类继承。

3.可以声明为final的。

4.编译以后生成OuterClass$InnerClass.class字节码文件。

注意事项:

1.非static的成员内部类中的成员不能声明为static的。

2.只有在外部类或static的成员内部类中才可声明static成员。

3.外部类访问成员内部类的成员,需要“内部类.成员” 或“内部类对象.成员”的方式。

4.成员内部类可以直接使用外部类的所有成员,包括私有的数据。

5.当想要在外部类的静态成员部分使用内部类时,可以考虑内部类声明为静态的。

局部内部类用法:

1.只能在声明它的方法或代码块中使用,而且是先声明后使用。

除此之外的任何地方都不能使用该类。

2.但是它的对象可以通过外部方法的返回值返回使用,

返回值类型只能是局部内部类的父类或父接口类型。

局部内部类特点:

1.内部类仍然是一个独立的类,在编译之后内部类会被编译成独立的.class文件,

但是前面冠以外部类的类名和$符号,以及数字编号。

2.只能在声明它的方法或代码块中使用,而且是先声明后使用。

除此之外的任何地方都不能使用该类。

3.局部内部类可以使用外部类的成员,包括私有的。

4.局部内部类可以使用外部方法的局部变量,但是必须是final的。

这是由局部内部类和局部变量的声明周期不同所致。

5.局部内部类和局部变量地位类似,不能使用public、protected、defunct、private。

6.局部内部类不能使用static修饰,因此也不能包含静态成员。

7.要使用内部类都分成两步:定义内部类、创建内部类对象。

匿名内部类的前提:

存在一个类或者接口,这里的类可以是具体类也可以是抽象类。

匿名内部类对象格式:new 类名或者接口名() {重写方法;}

本质:是一个继承了类或者实现了接口的子类匿名对象

匿名内部类对象的使用:调用单个方法

匿名内部类特点:

1.匿名内部类必须继承父类或实现接口

2.匿名内部类只能有一个对象

3.匿名内部类对象只能使用多态形式引用

匿名内部类注意:

1.匿名内部类不能定义任何静态成员、方法和类,只能创建匿名内部类的一个实例。

2.一个匿名内部类一定是在new的后面,用其隐含实现一个接口或实现一个类。

 public class AnonymousInner {

   public static void main(String[] args) {

    Outer.Inner inner =  new Outer().new Inner();

    //可以把两步骤合成一步

     //匿名内部类
      new Outer(); //匿名对象

     //定义一个匿名类对象
    new InnerObj() {
        //实现接口的方法
        public void test() {
          System.out.println("anonymous inner");
        }
     };

    //针对普通类,创建匿名内部类对象
     new InnerObject(10) {
       public void testObj() {
         System.out.println("testObj");
       }
     };

     //匿名内部类对象的使用
     new InnerObject(10) {
       public void testObj() {
         System.out.println("testObj");
       }
     }.testObj();

     //如果调用两次
     new InnerObject(10) {
       @Override
       public void testObj() {
         System.out.println("testObj");
       }
     }.testObj();

     InnerObject obj = new InnerObject(10) {
       @Override
       public void testObj() {
         System.out.println("testObj");
       }

       public void myOwn() {
         System.out.println("my own");
       }
     };
     obj.doWork();
     obj.testObj();

     //匿名内部类的弊端
     new InnerObject(10) {
       @Override
       public void testObj() {
         System.out.println("testObj");
       }

       public void myOwn() {
         System.out.println("my own");
       }
     }.myOwn();

   }

 }

 class Outer {
   class Inner {
     int i;
   }
 }

 interface InnerObj {
   void test();
 }
 class InnerObject{
   int i;
   public InnerObject(int i) {
     this.i = i;
   }
   public void testObj() {
     System.out.println("testObj");
   }

   public void doWork() {
     System.out.println("dowork");
   }
 }
 class Obj extends InnerObject{
   public Obj(int i) {
     super(i);
   }
   public void testObj() {
     System.out.println("test test");
   }
 }
 public class SyntaxDemo {
   public static void main(String[] args) {
     //测试外部类访问内部类成员
     OuterClass outerClass = new OuterClass();
     outerClass.testInnerAccess();
     OuterClass.StaticInner staticInner = new OuterClass.StaticInner();
   }
 }

 class OuterClass {
   private int i;
   private static double k;
   public void testInnerAccess() {
     //创建内部类对昂
     InnerClass innerClass = new InnerClass();
     System.out.println(innerClass.j);
   }

   public static void testAccessFromStaicInner() {
     int m = 100;
     System.out.println("testAccessFromStaicInner");
   }
   //通过给成员位置内部类加private权限修饰符,让内部类只能被外部类访问到

   private class InnerClass {
     int j = 100;
     //定义一个方法来测试一下
     public void testOuterPrivate() {
       System.out.println(i);
     }
   }

        //被static权限修饰符所修饰
   static class StaticInner {
      //静态上下文不能访问非静态的成员变量和成员方法
     // private  int j = i;

     public void testAccess() {
       //静态上下文不能访问非静态的成员变量和成员方法

       //访问外部类的静态成员
       System.out.println(k);

       //访问外部类中的静态方法
       testAccessFromStaicInner();
     }
   }
 }

Java类成员之内部类的更多相关文章

  1. Java 类成员的初始化顺序

    Java 类成员的初始化顺序 前言:开发中碰到一个Java文件中有很多的成员变量,包括静态和非静态的,还有很多的初始化方法,很好奇这些成员的初始化顺序,在这里作个研究.   1  无继承情况下的Jav ...

  2. java类成员变量与代码块初始化

    首先根据下面的这个一段代码:引入关于java初始化顺序的问题public class InitationTest extends Person { public InitationTest() { S ...

  3. 【转】Java类成员变量默认初始化规则

    一个变量作为类成员使用的时候,如果没有被初始化,java会为其分配默认值: -------------------------------------------------------------- ...

  4. Java类成员访问控制权限

    类成员访问控制权限 在JAVA中有四种访问控制权限,分别为:private, default, protected, public 1.Private 如果一个成员方法或变量名前使用了private, ...

  5. Java类成员访问级别

    类可以是public或default(或包级别).在本教程中主要介绍 public,private,protected 这几个访问级别修辞符的使用.类成员的访问级别确定程序的哪个区域可以访问它. 以下 ...

  6. java类成员的默认可访问性是什么?你猜

    先看下面TestModel: import org.apache.commons.collections4.BidiMap; import org.apache.commons.collections ...

  7. java学习面向对象之内部类

    什么是面向对象内部类呢?所谓的内部类,即从字面意义上来理解的话,就是把类放到类当中. 那么内部类都有什么特点呢? 1.内部类可以访问包裹他的类的成员. 2.如果包裹他的类想访问被其包裹的类的话就得实例 ...

  8. Java核心技术点之内部类

    1. 为什么要使用内部类     内部类就是定义在一个类内部的类,那么为什么要使用内部类呢?主要原因有以下几点:第一,内部类中定义的方法能访问到它所在外部类的私有属性及方法:第二,外部类无法实现对同一 ...

  9. Java类成员(成员变量和方法)的覆盖与隐藏归纳

    以前就知道重写override和重载overload的区别,平时也是逮着用就是了,Eclipse报错再说. 最近看一本书里面出现了重写.替换.覆盖.置换.隐藏.重载,简直乱得不行,归纳整理一下. 从全 ...

随机推荐

  1. 关于浏览器ip代理导致定位错乱问题的坑

    http://m.welltrend.com.cn/网站在Android手机的qq浏览器或者uc浏览器或者在微信中打开连接访问时,点击右侧的聊天按钮,经常出现手机在北京结果定位到天津的问题,或者广州的 ...

  2. PyCharm自定义代码块设置方法-添加-删除【详细步骤】

    原文:https://blog.csdn.net/chichu261/article/details/82887108 在做项目的时候,有些代码会需要频繁的码.如果去已有的项目中去复制,又需要找很久. ...

  3. 如何解决vue项目中 scss 不支持 scoped 的 /deep/ 穿透写法

    如何解决vue项目中 scss 不支持 scoped 的 /deep/ 穿透写法 用过vue的人估计都用过scoped样式属性,但有时候需要穿透样式,啥办? 很多资料都说用>>> 或 ...

  4. win10 uwp 使用 AppCenter 自动构建

    微软在今年7月上线 appcenter.ms 这个网站,通过 App Center 可以自动对数千种设备进行适配测试.快速将应用发送给测试者或者直接发布到应用商店.做到开发的构建和快速测试,产品的遥测 ...

  5. P1044 最大值最小化

    题目描述 在印刷术发明之前,复制一本书是一个很困难的工作,工作量很大,而且需要大家的积极配合来抄写一本书,团队合作能力很重要.当时都是通过招募抄写员来进行书本的录入和复制工作的, 假设现在要抄写 \( ...

  6. H3C DNS简介

  7. H3C生成树协议

  8. linux 阻塞 open 作为对 EBUSY 的替代

    当设备不可存取, 返回一个错误常常是最合理的方法, 但是有些情况用户可能更愿意等待 设备. 例如, 如果一个数据通讯通道既用于规律地预期地传送报告(使用 crontab), 也用于根据 用户的需要偶尔 ...

  9. JS的防抖与节流学习笔记

    防抖(debounce):当持续触发事件时,在一定的时间段内,只有最后一次触发的事件才会执行. 例: function debounce(fn, wait) { var timer = null; r ...

  10. 1119 机器人走方格 V2 (组合数学)

    M * N的方格,一个机器人从左上走到右下,只能向右或向下走.有多少种不同的走法?由于方法数量可能很大,只需要输出Mod 10^9 + 7的结果.   Input 第1行,2个数M,N,中间用空格隔开 ...