今日学习 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. 将Hexo搭建到自己的服务器上

    http://xybin.top/posts/9373.html 第一部分:服务器端的操作 1.安装git 和nginx yum install -y nginx git 2.添加一个git用户 #添 ...

  2. Nodejs实现图片的上传、压缩预览、定时删除

    前言 我们程序员日常都会用到图片压缩,面对这么常用的功能,肯定要尝试实现一番.第一步,node基本配置 这里我们用到的是koa框架,它可是继express框架之后又一个更富有表现力.更健壮的web框架 ...

  3. Canal实现MySQL协议

    目录 代码流程 执行dump前 执行dump 在学习Canal的时候很好奇Canal是如何模拟成MySql Slave来接收数据的 MySql Slave会向主库发送dump协议来接收bin-log数 ...

  4. Linux YUM 配置源

    Linux Yum 简介 YUM是交互式的以rpm为基础的软件包管理工具.YUM可以根据仓库的元数据信息,去自动的实现系统更新,包括依赖性分析,过期软件包处理.我们也可以利用yum来进行软件安装,删除 ...

  5. 微服务追踪SQL(支持Isto管控下的gorm查询追踪)

    效果图 SQL的追踪正确插入到微服务的调用链之间 详细记录了SQL的执行内容和消耗时间 搜索SQL的类型 多线程(goroutine)下的追踪效果 在 Kubernetes 中部署微服务后,通过 Is ...

  6. springboot项目上传存储图片到七牛云服务器

    springboot项目上传存储图片到七牛云服务器 问题描述: 当图片存在本地时会出现卡顿的现象.比如一篇图文混排的文章,如果图片没有加载完,可能整个文章都显示不出来,因为它们都是用的同一个服务器. ...

  7. Tomcat深入浅出——Session与Cookie(四)

    一.Cookie 1.1 Cookie概念 Cookie:有时也用其复数形式 Cookies.类型为"小型文本文件",是某些网站为了辨别用户身份,进行Session跟踪而储存在用户 ...

  8. 各种Git Bash乱码解决

    乱码情景一: 当使用git log 出现乱码时,修改 %GIT_HOME%\etc\gitconfig 文件,加入如下内容: [gui] encoding = utf-8[i18n] commiten ...

  9. python+tkinter 简单的登录窗口demo

    一个简单的登录窗口布局,可以用于日常快速搭建一个简单的窗口类. from tkinter import * import tkinter.messagebox class LoginUi: def _ ...

  10. 2022-7-13 java_1 第七组 刘昀航

    @ 目录 前言 一.一些基本的指令 二.java 1.java的三个版本 2.java特点 3.运行一个java程序 三.java的数据类型 1.java基本数据类型 2.强制转换的原理 3.八种基本 ...