java学习day10(Java基础)特殊类
package com.lagou.task10;/*** 编程实现普通内部类的定义和使用 - 文档注释*/
public class NormalOuter {private int cnt = 1;// 定义普通内部类,隶属于外部类的成员,并且是对象层级/*private*/public /*final*/ class NormalInner {private int ia = 2;private int cnt = 3;public NormalInner() {System.out.println("普通内部类的构造方法体执行到了!");}public void show() {System.out.println("外部类中变量cnt的数值为:" + cnt); // 1System.out.println("ia = " + ia); // 2}public void show2(int cnt) {System.out.println("形参变量cnt = " + cnt); // 局部优先原则 4System.out.println("内部类中cnt = " + this.cnt); // 3System.out.println("外部类中cnt = " + NormalOuter.this.cnt); // 1}}
}
package com.lagou.task10;public class NormalOuterTest {public static void main(String[] args) {// 1.声明NormalOuter类型的引用指向该类型的对象NormalOuter no = new NormalOuter();// 2.声明NormalOuter类中内部类的引用指向内部类的对象NormalOuter.NormalInner ni = no.new NormalInner();// 调用内部类中的show方法ni.show();System.out.println("---------------------------------------------");ni.show2(4);}
}
package com.lagou.task10;/*** 实现静态内部类的定义和使用*/
public class StaticOuter {private int cnt = 1; // 隶属于对象层级private static int snt = 2; // 隶属于类层级public /*static*/ void show() {System.out.println("外部类的show方法就是这里!");}/*** 定义静态内部类 有static关键字修饰隶属于类层级*/public static class StaticInner {private int ia = 3;private static int snt = 4;public StaticInner() {System.out.println("静态内部类的构造方法哦!");}public void show() {System.out.println("ia = " + ia); // 3System.out.println("外部类中的snt = " + snt); // 2//System.out.println("外部类的cnt = " + cnt); // Error:静态上下文中不能访问非静态的成员,因此此时可能还没有创建对象}public void show2(int snt) { // 就近原则System.out.println("snt = " + snt); // 5System.out.println("内部类中的成员snt = " + StaticInner.snt); // 4System.out.println("外部类中的成员snt = " + StaticOuter.snt); // 2//StaticOuter.show();new StaticOuter().show();}}
}
package com.lagou.task10;public class StaticOuterTest {public static void main(String[] args) {// 1.声明StaticInner类型的引用指向该类型的对象StaticOuter.StaticInner si = new StaticOuter.StaticInner();// 2.调用show方法进行测试si.show();System.out.println("---------------------------------------------");si.show2(5);}
}
package com.lagou.task10;/*** 编程实现局部内部类的定义和使用*/
public class AreaOuter {private int cnt = 1;public void show() {// 定义一个局部变量进行测试,从Java8开始默认理解为final关键字修饰的变量// 虽然可以省略final关键字,但建议还是加上final int ic = 4;// 定义局部内部类,只在当前方法体的内部好使 拷贝一份class AreaInner {private int ia = 2;public AreaInner() {System.out.println("局部内部类的构造方法!");}public void test() {int ib = 3;System.out.println("ia = " + ia); // 2System.out.println("cnt = " + cnt); // 1//ic = 5; ErrorSystem.out.println("ic = " + ic); // 4}}// 声明局部内部类的引用指向局部内部类的对象AreaInner ai = new AreaInner();ai.test();}}
package com.lagou.task10;public class AreaOuterTest {public static void main(String[] args) {// 1.声明外部类类型的引用指向外部类的对象AreaOuter ao = new AreaOuter();// 2.通过show方法的调用实现局部内容类的定义和使用ao.show();}
}
局部内部类的使用方式
package com.lagou.task10;public interface AnonymousInterface {// 自定义抽象方法public abstract void show();
}
package com.lagou.task10;public class AnonymousInterfaceTest {// 假设已有下面的方法,请问如何调用下面的方法?// AnonymousInterface ai = new AnonymousInterfaceImpl();// 接口类型的引用指向实现类型的对象,形成了多态public static void test(AnonymousInterface ai) {// 编译阶段调用父类版本,运行调用实现类重写的版本ai.show();}public static void main(String[] args) {//AnonymousInterfaceTest.test(new AnonymousInterface()); // Error:接口不能实例化AnonymousInterfaceTest.test(new AnonymousInterfaceImpl());System.out.println("---------------------------------------------------------------");// 使用匿名内部类的语法格式来得到接口类型的引用,格式为:接口/父类类型 引用变量名 = new 接口/父类类型() { 方法的重写 };AnonymousInterface ait = new AnonymousInterface() {@Overridepublic void show() {System.out.println("匿名内部类就是这么玩的,虽然你很抽象!");}};// 从Java8开始提出新特性lamda表达式可以简化上述代码,格式为:(参数列表) -> {方法体}AnonymousInterface ait2 = () -> System.out.println("lamda表达式原来是如此简单!");AnonymousInterfaceTest.test(ait2);}
}
package com.lagou.task10;public class AnonymousInterfaceImpl implements AnonymousInterface {@Overridepublic void show() {System.out.println("这里是接口的实现类!");}
}
package com.lagou.task10;/*** 编程实现所有方向的枚举,所有的方向:向上、向下、向左、向右*/
public class Direction {private final String desc; // 用于描述方向字符串的成员变量// 2.声明本类类型的引用指向本类类型的对象public static final Direction UP = new Direction("向上");public static final Direction DOWN = new Direction("向下");public static final Direction LEFT = new Direction("向左");public static final Direction RIGHT = new Direction("向右");// 通过构造方法实现成员变量的初始化,更加灵活// 1.私有化构造方法,此时该构造方法只能在本类的内部使用private Direction(String desc) {this.desc = desc;}// 通过公有的get方法可以在本类的外部访问该类成员变量的数值public String getDesc() {return desc;}
}
package com.lagou.task10;public class DirectionTest {public static void main(String[] args) {/*// 1.声明Direction类型的引用指向该类型的对象并打印特征Direction d1 = new Direction("向上");System.out.println("获取到的字符串是:" + d1.getDesc()); // 向上Direction d2 = new Direction("向下");System.out.println("获取到的字符串是:" + d2.getDesc()); // 向下Direction d3 = new Direction("向左");System.out.println("获取到的字符串是:" + d3.getDesc()); // 向左Direction d4 = new Direction("向右");System.out.println("获取到的字符串是:" + d4.getDesc()); // 向右System.out.println("-------------------------------------");Direction d5 = new Direction("向前");System.out.println("获取到的字符串是:" + d5.getDesc()); // 向前*///Direction.UP = 2; Error:类型不匹配//Direction d2 = null;//Direction.UP = d2; Error: final关键字修饰Direction d1 = Direction.UP;System.out.println("获取到的方向是:" + d1.getDesc()); // 向上System.out.println("-------------------------------------");// 使用一下Java5开始的枚举类型DirectionEnum de = DirectionEnum.DOWN;System.out.println("获取到的方向是:" + de.getDesc()); // 向下}
}
package com.lagou.task10;/*** 编程实现方向枚举类的测试,调用从Enum类中继承下来的方法*/
public class DirectionEnumTest {public static void main(String[] args) {// 1.获取DirectionEnum类型中所有的枚举对象DirectionEnum[] arr = DirectionEnum.values();// 2.打印每个枚举对象在枚举类型中的名称和索引位置for (int i = 0; i < arr.length; i++) {System.out.println("获取到的枚举对象名称是:" + arr[i].toString());System.out.println("获取到的枚举对象对应的索引位置是:" + arr[i].ordinal()); // 和数组一样下标从0开始}System.out.println("---------------------------------------------------------------");// 3.根据参数指定的字符串得到枚举类型的对象,也就是将字符串转换为对象//DirectionEnum de = DirectionEnum.valueOf("向下"); // 编译ok,运行发生IllegalArgumentException非法参数异常DirectionEnum de = DirectionEnum.valueOf("DOWN");//DirectionEnum de = DirectionEnum.valueOf("UP LEFT"); // 要求字符串名称必须在枚举对象中存在//System.out.println("转换出来的枚举对象名称是:" + de.toString());System.out.println("转换出来的枚举对象名称是:" + de); // 当打印引用变量时,会自动调用toString方法System.out.println("---------------------------------------------------------------");// 4.使用获取到的枚举对象与枚举类中已有的对象比较先后顺序for(int i = 0; i < arr.length; i++) {// 当调用对象在参数对象之后时,获取到的比较结果为 正数// 当调用对象在参数对象相同位置时,则获取到的比较结果为 零// 当调用对象在参数对象之前时,则获取到的比较结果为 负数System.out.println("调用对象与数组中对象比较的先后顺序结果是:" + de.compareTo(arr[i]));}System.out.println("---------------------------------------------------------------");// 5.使用数组中每个DirectionEnum对象都去调用show方法测试for (int i = 0; i < arr.length; i++) {arr[i].show();}}
}
package com.lagou.task10;public class DirectionUseTest {// 自定义静态方法实现根据参数指定的字符串内容来打印具体的方向信息public static void test1(String str) {switch (str) {case "向上":System.out.println("抬头望明月!"); break;case "向下":System.out.println("低头思故乡!"); break;case "向左":System.out.println("左牵黄"); break;case "向右":System.out.println("右擎苍"); break;default:System.out.println("没有这样的方向哦!");}}// 自定义静态方法实现根据参数指定的枚举类型来打印具体的方向信息public static void test2(DirectionEnum de) {switch (de) {case UP:System.out.println("抬头望明月!"); break;case DOWN:System.out.println("低头思故乡!"); break;case LEFT:System.out.println("左牵黄"); break;case RIGHT:System.out.println("右擎苍"); break;default:System.out.println("没有这样的方法哦!");}}public static void main(String[] args) {DirectionUseTest.test1(Direction.UP.getDesc());DirectionUseTest.test1("今天是个好日子!");System.out.println("--------------------------------------------");DirectionUseTest.test2(DirectionEnum.DOWN);//DirectionUseTest.test2("今天是个好日子!"); Error:类型不匹配,减少了出错的可能性}
}
Enum类的概念和方法
package com.lagou.task10;/*** 编程实现所有方向的枚举,所有的方向:向上、向下、向左、向右 枚举类型要求所有枚举值必须放在枚举类型的最前面*/
public enum DirectionEnum implements DirectionInterface {// 2.声明本类类型的引用指向本类类型的对象// 匿名内部类的语法格式:接口/父类类型 引用变量名 = new 接口/父类类型() { 方法的重写 };// public static final Direction UP = new Direction("向上") { 方法的重写 };UP("向上") {@Overridepublic void show() {System.out.println("贪吃蛇向上移动了一下!");}}, DOWN("向下") {@Overridepublic void show() {System.out.println("贪吃蛇向下移动了一下!");}}, LEFT("向左") {@Overridepublic void show() {System.out.println("左移了一下!");}}, RIGHT("向右") {@Overridepublic void show() {System.out.println("右移了一下!");}};private final String desc; // 用于描述方向字符串的成员变量// 通过构造方法实现成员变量的初始化,更加灵活// 1.私有化构造方法,此时该构造方法只能在本类的内部使用private DirectionEnum(String desc) { this.desc = desc; }// 通过公有的get方法可以在本类的外部访问该类成员变量的数值public String getDesc() {return desc;}// 整个枚举类型只重写一次,所有对象调用同一个/*@Overridepublic void show() {System.out.println("现在可以实现接口中抽象方法的重写了!");}*/
}
package com.lagou.task10;/*** 编程实现方向枚举类的测试,调用从Enum类中继承下来的方法*/
public class DirectionEnumTest {public static void main(String[] args) {// 1.获取DirectionEnum类型中所有的枚举对象DirectionEnum[] arr = DirectionEnum.values();// 2.打印每个枚举对象在枚举类型中的名称和索引位置for (int i = 0; i < arr.length; i++) {System.out.println("获取到的枚举对象名称是:" + arr[i].toString());System.out.println("获取到的枚举对象对应的索引位置是:" + arr[i].ordinal()); // 和数组一样下标从0开始}System.out.println("---------------------------------------------------------------");// 3.根据参数指定的字符串得到枚举类型的对象,也就是将字符串转换为对象//DirectionEnum de = DirectionEnum.valueOf("向下"); // 编译ok,运行发生IllegalArgumentException非法参数异常DirectionEnum de = DirectionEnum.valueOf("DOWN");//DirectionEnum de = DirectionEnum.valueOf("UP LEFT"); // 要求字符串名称必须在枚举对象中存在//System.out.println("转换出来的枚举对象名称是:" + de.toString());System.out.println("转换出来的枚举对象名称是:" + de); // 当打印引用变量时,会自动调用toString方法System.out.println("---------------------------------------------------------------");// 4.使用获取到的枚举对象与枚举类中已有的对象比较先后顺序for(int i = 0; i < arr.length; i++) {// 当调用对象在参数对象之后时,获取到的比较结果为 正数// 当调用对象在参数对象相同位置时,则获取到的比较结果为 零// 当调用对象在参数对象之前时,则获取到的比较结果为 负数System.out.println("调用对象与数组中对象比较的先后顺序结果是:" + de.compareTo(arr[i]));}System.out.println("---------------------------------------------------------------");// 5.使用数组中每个DirectionEnum对象都去调用show方法测试for (int i = 0; i < arr.length; i++) {arr[i].show();}}
}
枚举类实现接口的方式
package com.lagou.task10;public interface DirectionInterface {// 自定义抽象方法public abstract void show();
}
package com.lagou.task10;import java.lang.annotation.*;//@Retention(RetentionPolicy.SOURCE) // 表示下面的注解在源代码中有效
//@Retention(RetentionPolicy.CLASS) // 表示下面的注解在字节码文件中有效,默认方式
@Retention(RetentionPolicy.RUNTIME) // 表示下面的注解在运行时有效
@Documented // 表示下面的注解信息可以被javadoc工具提取到API文档中,很少使用
// 表示下面的注解可以用于类型、构造方法、成员变量、成员方法、参数 的修饰
@Target({ElementType.TYPE, ElementType.CONSTRUCTOR, ElementType.FIELD, ElementType.METHOD, ElementType.PARAMETER})
@Inherited // 表示下面的注解所修饰的类中的注解使用可以被子类继承
// 若一个注解中没有任何的成员,则这样的注解叫做标记注解/标识注解
public @interface MyAnnotation {//public Direction value(); // 声明一个String类型的成员变量,名字为value 类型有要求public String value() default "123"; // 声明一个String类型的成员变量,名字为valuepublic String value2();
}
package com.lagou.task10;// 表示将标签MyAnnotation贴在Person类的代码中,使用注解时采用 成员参数名 = 成员参数值, ...
//@MyAnnotation(value = "hello", value2 = "world")
@MyAnnotation(value2 = "world")
public class Person {/*** name是用于描述姓名的成员变量*/@MyAnnotation(value2 = "1")private String name;/*** age是用于描述年龄的成员变量*/private int age;/*** 编程实现无参构造方法*/@MyAnnotation(value2 = "2")public Person() {}/*** 编程实现有参构造方法* @param name* @param age*/public Person(@MyAnnotation(value2 = "4") String name, int age) {this.name = name;this.age = age;}/*** 自定义成员方法实现特征的获取和修改* @return*/@MyAnnotation(value2 = "3")public String getName() {return name;}public void setName(String name) {this.name = name;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}
}
元注解的概念
元注解@Inherited
package com.lagou.task10;// 也就是可以继承Person类的注解
public class Student extends Person {
}
package com.lagou.task10;import java.lang.annotation.ElementType;
import java.lang.annotation.Repeatable;
import java.lang.annotation.Target;/*** 自定义注解用于描述任务的角色*/
@Repeatable(value = ManTypes.class)
@Target(ElementType.TYPE_USE)
public @interface ManType {String value() default "";
}
package com.lagou.task10;@ManType(value = "职工")
@ManType(value = "超人")
//@ManTypes({@ManType(value = "职工"), @ManType(value = "超人")}) // 在Java8以前处理多个注解的方式
public class Man {@Deprecated // 表示该方法已经过时,不建议使用public void show() {System.out.println("这个方法马上过时了!");}public static void main(String[] args) {int ia = 97;char c1 = (@ManType char) ia;}
}
package com.lagou.task10;import java.lang.annotation.ElementType;
import java.lang.annotation.Target;/*** 自定义注解里面可以描述多种角色*/
@Target(ElementType.TYPE_USE)
public @interface ManTypes {ManType[] value();
}
java学习day10(Java基础)特殊类相关推荐
- Java学习日记1——基础认知
Java学习日记1--基础认知 学习Java阶段,如果发现不正确的描述,还请指正! 首先附上Java相关下载链接和配置教程链接 Java相关软件工具下载地址:官方下载 Java环境配置(win10配置 ...
- Java学习07–前端基础之CSS
Java学习07–CSS基础 1.CSS介绍 1.1.发展史 css1.0 基本 css2.0 div(块)+css html与css结构分离的思想网页变简单 css2.1 浮动,定位 css3.0 ...
- Java学习---Day16_IO流基础篇
Java学习-Day16_IO流基础篇 文件操作 操作磁盘上的某一个文件或某一个文件夹,可以对他们进行创建或删除.移动.属性获取.属性设置等操作.但是,不包含读取文件的内容.拷贝文件 ps:java中 ...
- Java学习笔记之基础篇
Java学习笔记之基础篇 目录 Java如何体现平台的无关性? 面向对象(OO)的理解 面向对象和面向过程编程的区别 面向对象三大特征 静态绑定和动态绑定(后期绑定) 延伸:类之间的关系 组合(聚合) ...
- Java学习路线-夯实基础
Java学习路线-夯实基础 第一部分:网络与操作系统 第二部分:数据结构与算法 第三部分:Java基础 第四部分:Java设计模式 第五部分:数据库 第六部分:Redis 第七部分:并发与多线程 第八 ...
- invader的java学习第一天基础篇
invader的java学习第一天基础篇 一.java主要历史 ①java是Sun公司的产品,09年被Oracle公司收购. ②java语言之父:詹姆士高斯林 二.jdk.jre.jvm三者关系 jd ...
- invader的java学习第二天基础篇
invader的java学习第二天基础篇 一.深入了解第一个Hello World程序 public class Hello World{ public static void main(String ...
- JAVA学习之路--基础篇三
目录 关于Java中从键盘输入的语句 nextxxx().next().nextLine()的区别 语句 if和if else语句 Switch语句 for语句 while和do..while bre ...
- Java学习资源 | Java编程最新教学视频大全,推荐
Java资源合集(视频版) 入门 进阶 高级 样样俱全 学习资源很多,学习方法也很多 适合自己才是最好的 可以试听一下,选择最适合的 加油! 众说周知 B站是一个强大的学习网站 视频 韩顺平零基础30 ...
- Java学习:Java就业前景
Java学习:Java就业前景 在2019年的互联网行业中,中高级Java程序员加速批量加入了求职市场,在薪资波动的同时,初级Java程序员的求职生存空间被严重挤压.而各个大厂的裁员,流入求职市场大量 ...
最新文章
- python编程计算1!+2!+...+10!_如何用C语言编程计算 1!+2!+3!+…+10!?
- 有关session的登录注销的一个小例子
- [SpringBoot2]web场景_静态资源规则与定制化
- parrot linux 安装grub,parrotsec 和 kali安装系统的时候出现“executing grub-install dummy”的解决方案...
- mysql 日志文件 自动_自动恢复MySQL数据库的日志文件思路分享及解决方案
- php基础自测卷2,php基础2
- 浅谈软件测试人员不要这样写测试用例(给测试新手和老鸟的提示)
- RabbitMQ中queueBind和exchangeBind方法
- 如何快速构建一个 Spring Boot 工程?
- PL/SQL学习笔记之存储过程
- JSP的九大内置对象
- Padavan安装使用ZeroTier实现组建虚拟局域网的方法
- 高中物理知识补充——电容电感充放电极性判断
- Jrebel使用+激活码
- corelDraw 的CDR格式解析
- 90后歌单精选100首,我有歌,你有故事吗?
- 世上本没有对错,看问题的角度不同,答案不同而已,我们应该学会常常用别人的角度看世界,多一分宽容,多一分理解,多一分求同存异。
- 改进集束搜索(Refinements to Beam Search)
- java实现将多个word文档合并
- QT_disconnect
热门文章
- JAVA中如何解决超卖,Redis解决库存超卖问题实例讲解
- 利用Vue制作一个商品管理页面(第二部分,小完结)
- 无线桥连后不能访问服务器,路由器设置无线桥接后不能登录副路由器怎么办?...
- 从有状态应用(Session)到无状态应用(JWT),以及 SSO 和 OAuth2
- 示波器基本原理之一:带宽
- 解决win10小娜Cortana(win+S)无法搜索本地应用或无反应
- 绝对受用的求职经验分享
- 简易学籍管理系统(3)--插入结点并排序
- 【区块链108将】千方基金点付大头:投资区块链,不要让过往认知限制你的想象...
- 虚无世界java路_[AoA3]虚无世界3 (Advent of Ascension 3)