※静态入参匹配、动态入参匹配和动态入参匹配plus

※静态入参匹配

- -根据入参变量的编译时类型决定调用哪个方法

(谁入参到这个方法就根据谁的编译时类型来决定)

/**
 * @author Lantzrung
 * @date 2022年7月22日
 * @Description
 */
public class Test03 {
	
	//定义方法
	public void test(A a) {
		System.out.println("test-------------A");
	}
	public void test(B b) {
		System.out.println("test-------------B");
	}
	public void test(C c) {
		System.out.println("test-------------C");
	}

public static void main(String[] args) {
	//创建实例对象
	Test03 test03 = new Test03();
	//操作一:
	A a = new A();
	B b = new B();
	//
	test03.test(a);//test-------------A
	test03.test(b);//test-------------B
	
	//操作二:
	A a1 = new B();
	B b1 = new C();
	A a_b = b1;
	//(没有多态时):在确认同一个类时,根据方法签名【入参的变量的编译时类型】决定
	//根据方法签名
	test03.test(a1);//test-------------A
	test03.test(b1);//test-------------B
	test03.test(a_b);//test-------------A
}
}
// A --> B --> C
class A{
}
class B extends A{
}
class C extends B{
}

※动态入参匹配

- -根据调用方法的引用变量的运行时类型决定调用哪个类

(谁调用了这个方法就根据谁的运行时类型来决定)

1、确定调用哪个类【调用方法的变量的运行时类型确定】

2、确定调用哪个方法【入参的变量的编译时类型确定】

/**
 * @author Lantzrung
 * @date 2022年7月22日
 * @Description
 */
package com.g0714work;

public class Test04 {
	public static void main(String[] args) {

//		//操作一:
//		A a = new A();
//		B b = new B();
//		C c = new C();
//		
//		//输出结果:
//		a.test(c);//A----c
//		b.test(a);//B----a

		// 操作二:
		// 1、确定调用哪个类【调用方法的变量的运行时类型确定】
		// 2、确定调用哪个方法【入参的变量的编译时类型确定】
		A a = new A();
		B b = new B();
		A a_c = new C();
		A a_b = b;

		// 输出结果:
		a_c.test(b);// C-------------b
		// 简单来说就是先确认运行时类型的就是new C();C类型,
		// 然后再确认编译时类型为B b,为b
		a_b.test(a);// B-------------a
		// 先确认运行时类型的就是new B();B类型,
		// 然后再确认编译时类型为A a,为a
		// 操作三:
		C cc = (C) a_c;
		cc.test(a_b);// C------------a
		// 先确认运行时类型的就是new C();C类型,
		// 然后再确认编译时类型为A a_b,为a

	}
}

// A --> B --> C
class A {
	// 定义方法
	public void test(A a) {
		System.out.println("A-------------a");
	}

	public void test(B b) {
		System.out.println("A-------------b");
	}

	public void test(C c) {
		System.out.println("A-------------c");
	}
}

class B extends A {
	// 定义方法
	public void test(A a) {
		System.out.println("B-------------a");
	}

	public void test(B b) {
		System.out.println("B-------------b");
	}

	public void test(C c) {
		System.out.println("B-------------c");
	}
}

class C extends B {
	// 定义方法
	public void test(A a) {
		System.out.println("C-------------a");
	}

	public void test(B b) {
		System.out.println("C-------------b");
	}

	public void test(C c) {
		System.out.println("C-------------c");
	}
}

※动态入参匹配plus

// 方法调用在编译的时候已经确定了,如果运行时类型有重写方法则显示子类特征

--// 1、先编译【test(A a)】,后运行【test(A a)】(看得见和看不见的问题)

--// 2、确定调用在哪个类中的方法【根据引用变量的运行时类型】

--// 3、确定调用在哪个方法【根据引用变量的编译时类型】

/**
 * @author Lantzrung
 * @date 2022年7月22日
 * @Description
 */

public class Test05 {
	public static void main(String[] args) {

		// 操作一:
		A a = new B();
		B b = new B();

		// 方法调用在编译的时候已经确认了,如果运行时类型有重写方法则显示子类特征
		// 编译的时候已经确定了类型了,运行的时候是确认有没有进行方法重写

		// 1、先编译【test(A a)】,后运行【test(A a)】
		// 2、确定调用哪个类【调用方法的变量的运行时类型确定】
		// 3、确定调用哪个方法【入参的变量的编译时类型确定】
//      注意:这里是还没有在classA中加入方法的 以下方法是操作二才加入的
//      public void test(B b) {
//		System.out.println("A-------------b");
//	    }
		a.test(b);// B------------a

//		//操作二:
//		A a = new B();
//		B b = new B();
//		a.test(b);// B------------b

	}
}

// A --> B --> C
class A {
	// 定义方法
	public void test(A a) {
		System.out.println("A-------------a");
	}

	public void test(B b) {
		System.out.println("A-------------b");
	}
}

class B extends A {
	// 定义方法
	public void test(A a) {
		System.out.println("B-------------a");
	}
	public void test(B b) {
		System.out.println("B-------------b");
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Lantzruk

你的鼓励是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值