内部类

内部类(inner class)是定义在另一个类中的类

内部类的好处:

|--1.隐藏机制:内部类封装性更好,隐藏在一个类之中,同一包中的其他类也不能访问

|--2.内部类可以访问外围类的私有数据

成员内部类

member inner class

可以访问外部类的所有成员变量和方法(无论静态、非静态)

自身没有静态成员

|--外部类里面创建成员内部类的实例:this.new Innerclass();

|--在外部类之外创建内部类的实例:new Outerclass().new Innerclass();

|--在内部类里访问外部类的成员:Outerclass.this.member

class Hero {
void callHorse() {
// 自己使用自己的成员内部类
System.out.print("吕布");
this.new Horse().show();
}
// 成员内部类
class Horse {
public void show() {
System.out.println("---赤兔---");
}
}
}
public class InnerClassMember {
public static void main(String[] args) {
Hero h = new Hero();
h.callHorse();
// 创建一个类的内部类
Hero.Horse horse = new Hero().new Horse();
horse.show();
}
}
吕布---赤兔---
---赤兔---

静态内部类

static inner class (nested class)

使用内部类只是为了把一个类隐藏在另外一个类的内部,并不需要内部类引用外围对象,可以将内部类声明为static。

生成静态内部类对象的方式为:

OuterClass.InnerClass inner = new OuterClass.InnerClass();// 里面的类不用new

|--成员内部类没有静态成员;

|--静态内部类只能访问外围类的静态成员

局部内部类

local inner class

在方法中定义、使用

不能被public, protected, private和static修饰(像局部变量一样)

只能访问方法中定义的final类型的局部变量(初始化之后便不能更改)

import java.util.*;
// 以集合排序需要实现Comparator接口为例
public class TestInnerClassLocal {
public static void main(String[] args) {
class InnerComparator implements Comparator<Integer> {
@Override
public int compare(Integer o1, Integer o2) {
return o2 - o1;
}
}
// 需要先定义局部内部类,再使用
InnerComparator com = new InnerComparator();
List<Integer> lst = new ArrayList<>();
Collections.addAll(lst, 2, 3, 5, 1, 4);
Collections.sort(lst, com);
System.out.println(lst);
}
}
[5, 4, 3, 2, 1]

匿名内部类

anonymous inner class

没有名字的局部内部类。

用于只创建这个类的一个对象的场合(不必命名),通常是作为方法的参数

隐式地继承了一个父类或者实现了一个接口

限制:由于构造方法的名字与类名相同,而匿名类没有类名,所以,匿名类不能有构造方法。

综合代码:

import java.util.Date;
class OutClass {
private static String field_Static = "外围类:静态变量";
private String field_Common = "外围类:普通变量";
private static void methodStatic() {
System.out.println("外围类:静态方法");
}
private void methodCommon() {
System.out.println("外围类:普通方法");
}
// 成员内部类
class InnerClassMember {
// Err:
// private static String inner_fieldStatic = "内部类:静态变量";
private String inner_fieldCommon = "|---内部类:普通变量";
// Err:
// private static void innerMethodStatic() {}
private void innerMethodCommon() {
System.out.println("|---内部类:普通方法");
}
public void methodInner() {
// 变量·外
System.out.println(OutClass.this.field_Common);
System.out.println(field_Static);
// 变量·内
System.out.println(inner_fieldCommon);
// 方法·外
methodStatic();
OutClass.this.methodCommon();
// 方法·内
innerMethodCommon();
}
}
// 静态内部类
static class InnerClassStatic {
private static String inner_fieldStatic = "|---静态内部类:静态变量";
private String inner_fieldCommon = "|---静态内部类:普通变量";
private static void innerMethodStatic() {
System.out.println("|---静态内部类:静态方法");
}
private void innerMethodCommon() {
System.out.println("|---静态内部类:普通方法");
}
public void methodInner() {
// 变量·外
System.out.println(OutClass.field_Static);
// 变量·内
System.out.println(inner_fieldCommon);
System.out.println(inner_fieldStatic);
// 方法·外
OutClass.methodStatic();
// 方法·内
innerMethodStatic();
innerMethodCommon();
}
}
// 局部內部類
public void method4InnerClassLocal() {
String localField = "局部变量";
final String localFieldFinal = "局部变量(final)";
// ↑Java 8中不用加final,但局部内部类中不能修改其值
// 局部内部类
class InnerClassLocal {
public void localClassM() {
// Err: System.out.println(localField);
System.out.println(localFieldFinal);
System.out.println(field_Common);
System.out.println(field_Static);
methodCommon();
methodStatic();
}
}
InnerClassLocal _local_in_c = new InnerClassLocal();
_local_in_c.localClassM();
}
// --------------------
public void testAnonymousClass() {
// 匿名内部类
PrintDate(new Date() {
public long getTime() {
System.out.println(field_Common);
System.out.println(field_Static);
methodCommon();
methodStatic();
return 10086;
}
});
}
private void PrintDate(Date dt) {
System.out.println(dt.getTime());
}
}
public class InnerClassTest1 {
public static void main(String[] args) {
System.out.println("===↓↓↓成员内部类===================");
OutClass.InnerClassMember ic = new OutClass().new InnerClassMember();
ic.methodInner();
System.out.println("===↓↓↓静态内部类===================");
OutClass.InnerClassStatic ics = new OutClass.InnerClassStatic();
ics.methodInner();
System.out.println("===↓↓↓局部内部类===================");
OutClass oc = new OutClass();
oc.method4InnerClassLocal();
System.out.println("===↓↓↓匿名内部类===================");
oc.testAnonymousClass();
}
}
===↓↓↓成员内部类===================
外围类:普通变量
外围类:静态变量
|---内部类:普通变量
外围类:静态方法
外围类:普通方法
|---内部类:普通方法
===↓↓↓静态内部类===================
外围类:静态变量
|---静态内部类:普通变量
|---静态内部类:静态变量
外围类:静态方法
|---静态内部类:静态方法
|---静态内部类:普通方法
===↓↓↓局部内部类===================
局部变量(final)
外围类:普通变量
外围类:静态变量
外围类:普通方法
外围类:静态方法
===↓↓↓匿名内部类===================
外围类:普通变量
外围类:静态变量
外围类:普通方法
外围类:静态方法
10086

对比和总结

面试题

面试题:

1、静态内部类和成员内部类有什么不同?(美团)

2、Anonymous Inner Class (匿名内部类)是否可以继承其它类,是否可以implements(实现)interface(接口)?

3、补全代码:

interface Inter {
public void show();
}
class Outer {
public static Inter method() {// 返回值是接口的方法
// 补全代码↓↓↓
return
// 补全代码↑↑↑
}
}
public class OuterDemo {
public static void main(String[] args) {
Outer.method().show();
}
}

Java基础教程——内部类的更多相关文章

  1. Java基础教程:内部类

    Java基础教程:内部类 内部类 内部类,是指在一个类的内部定义的类.就像下面这样: public class EnclosingClass {   . . .   public class Nest ...

  2. Java基础教程(12)--深入理解类

    一.方法的返回值   当我们在程序中调用方法时,虚拟机将会跳转到对应的方法中去执行.当以下几种情况发生时,虚拟机将会回到调用方法的语句并继续向下执行: 执行完方法中所有的语句: 遇到return语句: ...

  3. Java基础教程(18)--继承

    一.继承的概念   继承是面向对象中一个非常重要的概念,使用继承可以从逻辑和层次上更好地组织代码,大大提高代码的复用性.在Java中,继承可以使得子类具有父类的属性和方法或者重新定义.追加属性和方法. ...

  4. Java基础教程:注解

    Java基础教程:注解 本篇文章参考的相关资料链接: 维基百科:https://zh.wikipedia.org/wiki/Java%E6%B3%A8%E8%A7%A3 注解基础与高级应用:http: ...

  5. Java基础教程:网络编程

    Java基础教程:网络编程 基础 Socket与ServerSocket Socket又称"套接字",网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端称为一个s ...

  6. Java基础教程(5)--变量

    一.变量 1.变量的定义   正如上一篇教程<Java基础教程(4)--面向对象概念>中介绍的那样,对象将它的状态存在域中.但是你可能仍然有一些疑问,例如:命名一个域的规则和惯例是什么?除 ...

  7. Java基础教程:Lambda表达式

    Java基础教程:Lambda表达式 本文部分内容引用自OneAPM:http://blog.oneapm.com/apm-tech/226.html 引入Lambda Java 是一流的面向对象语言 ...

  8. Java基础教程:泛型基础

    Java基础教程:泛型基础 引入泛型 传统编写的限制: 在Java中一般的类和方法,只能使用具体的类型,要么是基本数据类型,要么是自定义类型.如果要编写可以应用于多种类型的代码,这种刻板的限制就会束缚 ...

  9. Java基础教程:多线程基础(1)——基础操作

    Java:多线程基础(1) 实现多线程的两种方式 1.继承Thread类 public class myThread extends Thread { /** * 继承Thread类,重写RUN方法. ...

随机推荐

  1. D. Concatenated Multiples 解析(思維)

    Codeforce 1029 D. Concatenated Multiples 解析(思維) 今天我們來看看CF1029D 題目連結 題目 給你一個序列\(a\)和一個數字\(k\),求有幾種ind ...

  2. 走在深夜的小码农 Fifth Day

    Css3 Fifth Day writer:late at night codepeasant 学习大纲: 一.css三大特性 1.层叠性 ​ 相同选择器给设置相同的样式,此时一个样式就会覆盖(层叠) ...

  3. STM32入门系列-STM32时钟系统,STM32时钟树

    时钟对于单片机来说是非常重要的,它为单片机工作提供一个稳定的机器周期从而使系统能够正常运行.时钟系统犹如人的心脏,一旦有问题整个系统就崩溃.我们知道STM32属于高级单片机,其内部有很多的外设,但不是 ...

  4. JMeter实战(三) 界面使用

    JMeter 有 2 种运行方式,一种是 CLI,一种是 GUI,本篇文章就来介绍一下后者,图形用户界面,因为后续文章大部分都是基于 GUI 的. 本文演示的是英文版,想用中文的同学可以在菜单栏点击 ...

  5. 2018-12-5 及 codeforces round 525v2

    突然发现五天没记录了,这五天学习完全没有按着正常规划进行,先罗列一下吧. 机器学习视频第一周的全部看完了. 算法导论看了几页. 参加了一次CF.rating只加了20,看来提高实力才是最关键的. C+ ...

  6. Java反射复习笔记

    目录 反射 获取反射的三种方式: Class对象的功能 获取 成员变量/成员变量们 获取 成员方法/成员方法们 获取构造方法们 获取全类名 Field:成员变量 Method:成员方法 Constru ...

  7. 【SpringCloud】08.客户端负载均衡器:Ribbon

    客户端负载均衡器:Ribbon Ribbon实现软负载均衡核心: 服务发现 :依据服务的名字,把该服务下所有的实例都找出来 服务选择规则:依据规则策略,如果从多个实例中,选出有效的服务 服务监听:检测 ...

  8. leetcode132:4sum

    题目描述 给出一个有n个元素的数组S,S中是否有元素a,b,c和d满足a+b+c+d=目标值?找出数组S中所有满足条件的四元组. 注意: 四元组(a.b.c.d)中的元素必须按非降序排列.(即a≤b≤ ...

  9. 转载:WIFI无线协议802.11a/b/g/n/ac的演变以及区别

    WIFI无线协议802.11a/b/g/n/ac的演变以及区别 版权声明:版权所有,转载须注明出处. https://blog.csdn.net/Brouce__Lee/article/details ...

  10. 模拟微信小程序页面Page方法

    1.依赖 a.jQuery b.angularjs 2.page.js文件 1 var Page = function (options) { 2 var myApp = angular.module ...