今日学习 2020-2-27

Java多态

多态性格式

/*
代码中体现多态性 其实就是一句话:父类指向子类对象
格式:
父类名称 对象名= new 子类名称();
或者
接口名称 对象名 = new 实现类名称(); */
public class Demo01Polymorphism {
public static void main(String[] args) {
//多态写法
//左侧父类的引用,指向了右侧子类的对象
Fu obj = new Zi();
obj.method();
obj.methodFu();
}
}
public class Fu {
public void method(){
System.out.println("父类方法");
}
public void methodFu(){
System.out.println("父类特有方法");
} }
public class Zi extends Fu {
@Override
public void method() {
System.out.println("子类方法");
}
}

成员变量问题

/*
访问成员变量的两种方式:
1.直接通过对象名称访问成员变量;看等号左边是谁,优先用谁,没有则向上找
2.间接通过成员方法访问:该方法属于谁优先用谁 没有则向上找
*/
public class Demo01MutiField {
public static void main(String[] args) {
//多态的写法
Fu obj = new Zi();
System.out.println(obj.num);
// System.out.println(obj.age);//错误写法
System.out.println("============");
//子类没有覆盖重写,就是父:10
//子类如果覆盖重写,就是字:20
obj.showNum(); }
}
//父类
public class Fu {
int num = 10; public void showNum(){
System.out.println(num);
}
}
//子类
public class Zi extends Fu {
int num = 20;
int age = 16; @Override
public void showNum() {
System.out.println(num);
}
}

成员方法

/*
多态中的代码中,成员方法的访问规则是:
看new的是谁,就优先用谁,没有则向上找 口诀:编译看左,运行看右边
成员变量:编译看左,运行还看左 */
public class Demo02MultiMethod {
public static void main(String[] args) {
Fu obj = new Zi();//多态 obj.method();//父子都有,优先用子
obj.methodFu();//子类没有,父类有,向上找 // obj.methodZi();//编译出错,左边是父类,当中没有methodZi方法所以编译报错 }
} public class Fu {
int num = 10; public void showNum(){
System.out.println(num);
}
public void method(){
System.out.println("父类方法");
}
public void methodFu(){
System.out.println("父类特有方法");
}
} public class Zi extends Fu {
int num = 20;
int age = 16; @Override
public void showNum() {
System.out.println(num);
}
@Override
public void method(){
System.out.println("子类方法");
}
public void methodZi(){
System.out.println("子类特有方法");
}
}

对象的向上转型

public class Demo01Main {
public static void main(String[] args) {
//对象的向上转型,就是父类引用指向子类对象
Animal animal = new Cat();
animal.eat();
}
} public abstract class Animal {
public abstract void eat();//抽象方法 } public class Cat extends Animal { @Override
public void eat() {
System.out.println("猫吃鱼");
}
}

向下转型

/*
向上转型一定是安全的,没有问题的,正确的。但是也有一个弊端
对象一旦向上转型为父类,那么就无法调用子类原本特有的内容 解决方法:
用对象的向下转型【还原】
格式:
子类名称 对象名 = (子类名称) 父类对象;
含义:将父类对象,还原 成为本来的子类对象 */
public class Demo01Main {
public static void main(String[] args) {
//对象的向上转型,就是父类引用指向子类对象
Animal animal = new Cat();//本来创建的是一只猫
animal.eat();
// animal.catchMouse();//错误方法 //还原 Cat cat = (Cat) animal; cat.catchMouse(); //下面是错误的转型
// Dog dog = (Dog) animal;//错误写法,编译不会报错,但是运行会报错
//java.lang.ClassCastException 类转换异常
}
} public class Cat extends Animal { @Override
public void eat() {
System.out.println("猫吃鱼");
}
//子类特有方法
public void catchMouse(){
System.out.println("猫抓老鼠");
}
} public class Dog extends Animal {
@Override
public void eat() {
System.out.println("狗吃SHIt");
}
public void WacthHouse(){
System.out.println("看家");
}
}

instanceof关键字

/*
r如何才能知道一个父类引用的对象,本来是上面子类
格式:
对象 instanceof 类名称
这将会得到一个boolean值结果,也就是判断前面的对象能不能当作后面类型的实例 */
public class Demo02Instanceof {
public static void main(String[] args) {
Animal animal = new Dog();//本来是Dog
animal.eat();//吃SHIT
//如果希望调用子类特有方法 需要向下转型‘
//判断一下父类引用animal本来是不是Dog
if (animal instanceof Dog){
Dog dog = (Dog) animal;
dog.WacthHouse();
}
//判断一下animal本来是不是Cat
if (animal instanceof Cat){
Cat cat = (Cat) animal;
cat.catchMouse();
}
giveMePet(new Dog());
}
public static void giveMePet(Animal animal){
if (animal instanceof Dog){
Dog dog = (Dog) animal;
dog.WacthHouse();
}
//判断一下animal本来是不是Cat
if (animal instanceof Cat){
Cat cat = (Cat) animal;
cat.catchMouse();
}
}
}

笔记本USB接口案例

public interface USB {
public abstract void open();//打开设备 public abstract void close();//关闭设备
} //鼠标就是一个USB设备
public class Mouse implements USB {
@Override
public void open() {
System.out.println("打开鼠标"); } @Override
public void close() {
System.out.println("关闭鼠标"); }
public void click(){
System.out.println("鼠标点击");
}
} //键盘就是一个USB设备
public class Keyboard implements USB {
@Override
public void open() {
System.out.println("打开键盘"); } @Override
public void close() {
System.out.println("关闭键盘"); }
public void type(){
System.out.println("键盘输入");
}
} public class Computer {
public void powerOn(){
System.out.println("笔记本电脑开机");
}
public void powerOff(){
System.out.println("笔记本电脑关机");
}
//使用USB设备的方法,使用接口作为方法发参数
public void useDevice(USB usb){
usb.open();//打开设备 if (usb instanceof Mouse){//先判断
Mouse mouse = (Mouse) usb;//向下转型
mouse.click();
}else if(usb instanceof Keyboard){//先判断
Keyboard keyboard = (Keyboard) usb;//向下转型
keyboard.type();
} usb.close();//关闭设备
}
} public class DemoMain {
public static void main(String[] args) {
//创建一个笔记本
Computer computer = new Computer(); computer.powerOn(); //首先进行向上转型
USB usbMouse = new Mouse();//多态写法
//参数是USB类型,我正好传递进去的就是USB鼠标
computer.useDevice(usbMouse); //创建一个USB键盘
Keyboard keyboard = new Keyboard();//没有使用多态写法
//方法参数是USB类型,传递进去的是实现类对象 类似 基本数据类型转换
computer.useDevice(keyboard);//正确写法
//computer.useDevice(new Keyboard());//正确写法 computer.powerOff();
}
}

发红包案例

Java基础——01的更多相关文章

  1. java基础 01

    java基础01 1. /** * JDK: (Java Development ToolKit) java开发工具包.JDK是整个java的核心! * 包括了java运行环境 JRE(Java Ru ...

  2. java基础01

    1. /** * JDK: (Java Development ToolKit) java开发工具包.JDK是整个java的核心! * 包括了java运行环境 JRE(Java Runtime Env ...

  3. 一、Java基础--01

    Java基础测试题分析 第一题是关于基本的算法知识,这个很有必要去掌握以下,在学校也经常听老师们说找工作比试面试会出一些这方面的知识,我拿到的第一题是关于排序的,虽然很简单,但是我还是要提醒一下基础不 ...

  4. java基础-01代理类

    简单的代理类实现案例主实现类:ProxyTestimport java.lang.reflect.InvocationHandler;import java.lang.reflect.Proxy;im ...

  5. Java基础01 ------ 从HelloWorld到面向对象

    Java是完全面向对象的语言.Java通过虚拟机的运行机制,实现“跨平台”的理念.我在这里想要呈现一个适合初学者的教程,希望对大家有用. "Hello World!" 先来看一个H ...

  6. 【Java基础01】Java InputStream的read方法

    JDK关于InputStream中的read方法的描述: (1) read() :  从输入流中读取数据的下一个字节,返回0到255范围内的int字节值.如果因为已经到达流末尾而没有可用的字节,则返回 ...

  7. java基础-01基本概念

    java的特点 跨平台 所谓的平台,我们可以理解为操作系统. 大部分语言是不能跨平台的,比如c语言的程序在windows和linux上需要编写不同的代码. java程序是运行在JVM(Java Vir ...

  8. Java基础01 从HelloWorld到面向对象(转载)

    Java是完全面向对象的语言.Java通过虚拟机的运行机制,实现“跨平台”的理念. "Hello World!" public class HelloWorld{    publi ...

  9. java 基础 01 变量和注释、数据类型

    1,变量和注释 比如:姓名:xiaoming 年龄:18 1.1变量的基本概念 当需要在程序中记录单个数据内容时,则需要声明一个变量来处理,而变量的本质就是内存中申请一块存储单元用于存储数据内容,由于 ...

随机推荐

  1. 南京大学 静态软件分析(static program analyzes)-- introduction 学习笔记

    一.Programming Languages体系 静态程序分析是编程语言中应用层面下的一个细分领域,它是一个非常重要的核心内容. 在理论部分,考虑的是如何设计一个语言的语法和语义,如何设计语言的类型 ...

  2. 手把手教你实现一个图片压缩工具(Vue与Node的完美配合)

    前言 图片压缩对于我们日常生活来讲,是非常实用的一项功能.有时我们会在在线图片压缩网站上进行压缩,有时会在电脑下软件进行压缩.那么我们能不能用前端的知识来自己实现一个图片压缩工具呢?答案是有的.效果展 ...

  3. 【react】什么是fiber?fiber解决了什么问题?从源码角度深入了解fiber运行机制与diff执行

    壹 ❀ 引 我在[react] 什么是虚拟dom?虚拟dom比操作原生dom要快吗?虚拟dom是如何转变成真实dom并渲染到页面的?一文中,介绍了虚拟dom的概念,以及react中虚拟dom的使用场景 ...

  4. IP寻址与规划

    一.IP寻址和子网划分 IP地址的主机部分可被分为三种地址:网络地址.主机地址和定向广播地址. 网络地址是网络号中的第一个地址.它用来将网络内的其他所有网段唯一标识为一个网段或广播域.定向广播地址是网 ...

  5. org/apache/poi/POIXMLTypeLoader或者java.lang.NoSuchFieldError: RETURN_NULL_AND_BLANK

    原因是之前我的poi和ooxml版本有点低, 解决方案 将两者版本提高,我是将两者的版本都提高到了3.15

  6. 【cartogarpher_ros】二: 官方Demo的介绍与演示

    上一节我们介绍了在linux中快速安装集成ros环境的cartographer. 本节我们会来跑一些官方demo,用于测试cartographer是否正确安装,顺便看看cartographer的建图与 ...

  7. 4-5 Spring Boot

    1. 关于Spring Boot Spring Boot是Spring官方的一个产品,其本质上是一个基于Maven的.以Spring框架作为基础的进阶框架,很好的支持了主流的其它框架,并默认完成了许多 ...

  8. day06 Socket_线程API_线程并发安全

    使用多线程实现多客户端连接服务端 流程图 服务端代码改造: package socket; import java.io.BufferedReader; import java.io.IOExcept ...

  9. day04 缓冲字符流__异常处理

    缓冲字符流 缓冲字符输入流:java.io.BufferedReader 是一个高级的字符流,特点是块读文本数据,并且可以按行读取字符串. package io; import java.io.*; ...

  10. Solution -「HNOI2013」消毒

    弱化一下,先考虑在二维上解决问题. 题目就转化为:有 \(n\) 个点 \((i, j)\) 需要被覆盖,而我们每次可以选一行或一列去覆盖,求覆盖所有点的最少选择次数. 如果我们对于每一个 \((i, ...