内部类

内部类(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. KVM虚拟化管理平台WebVirtMgr部署及使用

    KVM虚拟化管理平台WebVirtMgr部署及使用   需求: 公司机房有一台2U的服务器(64G内存,32核),由于近期新增业务比较多,测试机也要新增,服务器资源十分有限.所以打算在这台2U服务器上 ...

  2. python读取文件遇到问题及解决

    用python的open()函数打开文件时, 1.文件写绝对路径报IOError: [Errno 2] No such file or directory.文件改为相对路径(只写文件名)解决该问题 2 ...

  3. python中,*args和**kwargs这两个参数的作用是什么?

    *args和**kwargs这两个都是不定长参数,可以解决函数中参数不固定的问题,*args可以把位置参数转化成元组,**kwagrs可以把关键字参数转化成字段

  4. 阿里云app原型设计

    软件需求分析与系统设计 https://edu.cnblogs.com/campus/zswxy/2018SE 这个作业要求在哪里 https://edu.cnblogs.com/campus/zsw ...

  5. Day12 HTML知识

    1.html初识 超文本标记语言(Hypertext Markup Language,HTML)通过标签语言来标记要显示的网页中的各个部分.一套规则,浏览器认识的规则 浏览器按顺序渲染网页文件,然后根 ...

  6. Spring Security 实战干货:客户端OAuth2授权请求的入口

    1. 前言 在Spring Security 实战干货:OAuth2第三方授权初体验一文中我先对OAuth2.0涉及的一些常用概念进行介绍,然后直接通过一个DEMO来让大家切身感受了OAuth2.0第 ...

  7. 在Windows进下build 高可用负载均衡与反向代理神器:HAProxy

    前言 HAProxy是一个款基于Linux的开源高可用的负载均衡与反向代理工具,与Nginx大同小异. 搜遍了全网,几乎都是基于Linux平台.Windows平台的要么就是多年前的旧版本,要么就是不兼 ...

  8. python文档自译:os模块-01【说明部分】

    15.1. os - Miscellaneous operating system interfaces This module provides a portable way of using op ...

  9. 源码分析:同步基础框架——AbstractQueuedSynchronizer(AQS)

    简介 AQS 全称是 AbstractQueuedSynchronizer,位于java.util.concurrent.locks 包下面,AQS 提供了一个基于FIFO的队列和维护了一个状态sta ...

  10. spark-submit提交python脚本过程记录

    最近刚学习spark,用spark-submit命令提交一个python脚本,一开始老报错,所以打算好好整理一下用spark-submit命令提交python脚本的过程.先看一下spark-submi ...