静态内部类和内部类的区别_内部类不能定义为抽象类

静态内部类和内部类的区别_内部类不能定义为抽象类今天稍微复习一下静态内部类和内部类的相关知识,平常很少用静态内部类静态内部类,不能访问外部类的非静态成员静态内部类不需要创建外部类的对象就可访问(外部类名.内部类比如newMyMain.Person().display();就创建了静态内部类对象)静态内部类可以有public、protected、默认的、private等多种类型(这个功能我倒是从来没听说,通过实验的确ok…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

今天稍微复习一下 静态内部类和 内部类的相关知识,平常很少用

静态内部类

  • 静态内部类,不能访问外部类的非静态成员
  • 静态内部类 不需要创建外部类的对象就可访问(外部类名.内部类 比如new MyMain.Person().display();就创建了静态内部类对象)
  • 静态内部类可以有public、protected、默认的、private等多种类型 (这个功能我倒是从来没听说,通过实验的确ok)


public class MyMain{ 
   
    private static String name = "kobe bryant";
    private String num = "001";
 
    // 静态内部类可以用public,protected,private修饰
   public static class Person { 
   
        // 静态内部类中可以定义静态或者非静态的成员
        private String address = "Los angeles";

        private static String x = "Laker";
        public String mail = "kobe@yahoo.com.cn";// 内部类公有成员

        public void display() { 
   
            // System.out.println(num);//不能直接访问外部类的非静态成员

            // 静态内部类不能访问外部类的非静态成员(包括非静态变量和非静态方法)
            System.out.println(name);// 只能直接访问外部类的静态成员

            // 静态内部类只能访问外部类的静态成员(包括静态变量和静态方法)
            System.out.println("Inner " + address);// 访问本内部类成员。
        }
    }

    public void printInfo() { 
   
        Person person = new Person();

        // 外部类访问内部类的非静态成员:实例化内部类即可
        person.display();

        // System.out.println(mail);//不可访问
        // System.out.println(address);//不可访问
        
        //访问内部类的成员,都要通过内部类的对象
        System.out.println(person.address);// 可以访问内部类的私有成员

        System.out.println(Person.x);// 外部类访问内部类的静态成员:内部类.静态成员
        System.out.println(person.x);// 这样也能访问,但是不推荐
        System.out.println(person.mail);// 可以访问内部类的公有成员
    }

   public static void main(String[] args) { 
   
        MyMain staticTest = new MyMain();
        staticTest.printInfo();
    }
}

运行结果:
kobe bryant
Inner Los angeles
Los angeles
Laker
Laker
kobe@yahoo.com.cn


当在MyMain类中访问静态内部类,直接可以 new Person();
当然如果在外部类中访问这个静态内部类,则必须 new MyMain.Person();

这个时候我试验了一下 如果定义person类为  private static class Person
那么在其他的类中 尝试访问Person 会报错


public class testMain{ 
   
	public static void main(String[] args) { 
   
		new MyMain.Person().display();//The type MyMain.Person is not visible
    }
}

内部类

  • 内部类中不能有静态成员
  • 可以访问外部类的成员变量(外部类名.this.变量名)
  • 可以定义在方法外(可以有访问修饰符)和方法内(不能有访问修饰符,这个就是匿名内部类了)
public class TestInner { 
   

	private static String name = "kobe bryant";
	private String num = "001";
	private String address = "GreenLand";

	class Person { 
   

		private String address = "Los angeles";

		public String mail = "kobe@yahoo.com.cn";// 内部类公有成员

		public void display() { 
   

			System.out.println(name);// 只能直接访问外部类的静态成员

			System.out.println(TestInner.this.address);//访问外部类的同名非静态成员变量

			System.out.println(address);// 访问本内部类成员。
		}

	}

	public static void main(String[] args) { 
   
		TestInner test = new TestInner();

		//即使在本类中想要调用Person类,都必须这样写,而不能直接 new Person()
		new TestInner().new Person().display();
	}

}

运行结果

kobe bryant
GreenLand
Los angeles

同样如果给person类定义为private,以下语句也会报错,说Person类不可见!
public class testMain{ 
   
	public static void main(String[] args) { 
   
		
		new TestInner().new Person().display();
    }
}

最后一点小补充

参考静态内部类和非静态内部类的区别中提到的 正常情况下,你不能在接口内部放置任何代码,但嵌套类可以作为接口的一部分,因为它是static 的。只是将嵌套类置于接口的命名空间内,这并不违反接口的规则,我试验了一下 ,无论是静态类还是非静态类都可以写在接口里。

public interface IShot { 
   

	
	class Animal{ 
   
		public  String name="fox";
	}
	
	static class Human{ 
   
		public String  name ="老王";
	}
	
}


public class TestInterface implements IShot { 
   

	public static void main(String[] args) { 
   
		
		System.out.println(new IShot.Animal().name);
		System.out.println(new IShot.Human().name);
	}
}
//运行结果
fox
老王


都过jad发现编译了生成了三个顶级类

ARtUBt.png

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/183155.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • sequencer是什么意思_centralism

    sequencer是什么意思_centralismsequencer产生transaction,而driver负责接收transaction。classmy_driverextendsuvm_driver#(my_transaction);

    2022年8月1日
    8
  • python 机器学习中模型评估和调参

    python 机器学习中模型评估和调参

    2021年11月21日
    47
  • BM3D算法相关笔记

    BM3D算法相关笔记三维矩阵主要原因就在于,三维矩阵中,第一维度代表行,第二维度代表列,第三维度代表页,当第三维度为1时,代表只有1页,自然缩减为二维。当第一维度为1时,代表只有一行,但是每页都有,所以,从物理的角度没有缩减为二维。http://blog.sina.com.cn/s/blog_7519cf530101ahsb.html

    2022年5月2日
    32
  • JAVA:基于ARCGIS二次开发可视化开发环境搭建

    JAVA:基于ARCGIS二次开发可视化开发环境搭建这两天为了搭建这么一个基于java的ArcGIS二次开发环境可着实花了一番心血。在网上搜索各种资料,大部分都是基于C#的,关于JAVA的很少,而且很杂乱,没有一个完整的、详细的、适合新手的这么一个教程。所以,当我在奋斗两天且重装一次系统,终于安装成功之后,写下这篇文章,让用java进行基于ArcEngine二次开发的人可以少走弯路。因为ArcEngine只能在32位系统上面运行,所以当前系统为64

    2022年7月23日
    15
  • decode encode区别_python decode和encode

    decode encode区别_python decode和encode#-*-coding:utf-8importsys”’*首先要搞清楚,字符串在Python内部的表示是unicode编码,因此,在做编码转换时,通常需要以unicode作为中间编码,即先将其他编码的字符串解码(decode)成unicode,再从unicode编码(encode)成另一种编码。decode的作用是将其他编码的字符串转换成unicode编码,如str1.decode(‘gb231…

    2022年10月7日
    3
  • 贪婪算法(贪心算法)「建议收藏」

    贪婪算法(贪心算法)「建议收藏」贪心算法简介:@anthor:QYX贪心算法是指:在每一步求解的步骤中,它要求“贪婪”的选择最佳操作,并希望通过一系列的最优选择,能够产生一个问题的(全局的)最优解。贪心算法每一步必须满足一下条

    2022年7月3日
    25

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号