Java中的重载、重写和重构的区别

Java中的重载、重写和重构的区别1、重载重载(overloaded):重载就是在同一个类中允许同时存在一个以上的同名方法,只要这些方法的参数个数或类型不同即可。我们知道构造方法的名称已经由类名决定,所以构造方法只有一个名称,但如果希望以不同的方式来实例化对象,就需要使用多个构造方法来完成。由于这些构造方法都需要根据类名进行命名,为了让方法名相同而形参不同的构造方法同时存在,必须用到“方法重载”,虽然方法重载起源于构造方…

大家好,又见面了,我是你们的朋友全栈君。

1、重载

重载(overloaded): 重载就是在同一个类中允许同时存在一个以上的同名方法,只要这些方法的参数个数或类型不同即可。

我们知道构造方法的名称已经由类名决定,所以构造方法只有一个名称,但如果希望以不同的方式来实例化对象,就需要使用多个构造方法来完成。由于这些构造方法都需要根据类名进行命名,为了让方法名相同而形参不同的构造方法同时存在,必须用到“方法重载”,虽然方法重载起源于构造方法,但是它也可以应用到其他方法中。

示例:在项目中创建OverLoadTest类,在类中编写add()方法的多个重载形式,然后在主方法中分别输出这些方法的返回值。

/**
 * 重载示例
 * 
 * @author pan_junbiao
 *
 */
public class OverLoadTest
{
	public static int add(int a, int b)
	{
		return a + b;
	}

	public static int add(int a, int b, int c)
	{
		return a + b + c;
	}

	public static double add(double a, double b)
	{
		return a + b;
	}

	/**
	 * 定义不定长参数方法
	 */
	public static int add(int... a)
	{
		int s = 0;
		for (int i = 0; i < a.length; i++)
		{
			s += a[i];
		}
		return s;
	}

	public static void main(String[] args)
	{
		System.out.println("调用add(int,int)方法:" + add(1, 2));
		System.out.println("调用add(int,int,int)方法:" + add(1, 2, 3));
		System.out.println("调用add(double,double)方法:" + add(2.1, 3.5));
		// 调用不定长参数方法
		System.out.println("调用不定长参数方法:" + add(1, 2, 3, 4, 5, 6, 7, 8, 9));
		System.out.println("调用不定长参数方法:" + add(1, 2));
	}
}

执行结果:

Java中的重载、重写和重构的区别

注意:虽然在方法重载中可以使用两个方法的返回类型不同,但只有返回类型不同并不足以区分两个方法的重载,还需要通过参数的个数以及参数的类型来设置。

重载的规则:

(1)必须具有不同的参数列表。

(2)可以有不同的返回类型,只要参数列表不同就可以了。

(3)可以有不同的访问修饰符。

(4)可以抛出不同的异常。

 

2、重写

重写(override):重写(还可以称为覆盖)就是在子类中将父类的成员方法的名称保留,重写成员方法的实现内容,更改成员方法的存储权限,或是修改成员方法的返回值类型(注意:重写父类成员方法的返回值类型是基于J2SE 5.0版本以上编译器提供的新功能)。

示例:在项目中创建Parent类和Children类,在Parent类中编写成员方法doSomething()和doIt(),使Children类继承Parent类,重写父类的这两个方法和构造方法,并新增doSomethingNew()方法。其中Children类的构造方法中使用super关键字调用父类的构造方法和成员方法等。

(1)创建Parent父类:

/**
 * 父类
 * 
 * @author pan_junbiao
 *
 */
public class Parent
{
	/**
	 * 构造方法
	 */
	public Parent()
	{
		System.out.println("父类构造方法!");
	}

	/**
	 * 成员方法
	 */
	protected void doSomething()
	{
		System.out.println("父类方法");
	}

	/**
	 * 成员方法,返回类型为Parent类型
	 */
	protected Parent doIt()
	{
		return new Parent();
	}
}

(2)创建Children子类,并继承父类:

/**
 * 子类
 * 
 * @author pan_junbiao
 *
 */
public class Children extends Parent // 继承父类
{
	/**
	 * 构造方法
	 */
	public Children()
	{
		// 调用父类构成方法
		super();

		// 调用父类成员方法
		super.doSomething();

		// 子类构造方法
		System.out.println("子类构造方法");
	}

	/**
	 * 子类新增方法
	 */
	public void doSomethingNew()
	{
		System.out.println("子类新增方法");
	}

	/**
	 * 重写父类方法
	 */
	public void doSomething()
	{
		System.out.println("子类重写父类方法");
	}

	/**
	 * 重写父类方法,返回类型为Children类型
	 */
	protected Children doIt()
	{
		return new Children();
	}
}

子类重写父类的方法还可以修改方法的返回值类型,但这只是在J2SE 5.0以上的版本中支持的新功能。示例中子类中的doIt()方法就使用了这个新功能,父类中的doIt()方法的返回值类型为Parent类,而子类中的doIt()方法的返回值类型为Children类,子类中重写了父类的doIt()方法。这种重写方式需要遵循一个原则,即重写的返回值类型必须是父类中同一方法返回值类型的子类,而Children类正是Parent类的子类。

注意:当重写父类方法时,修改方法的修饰权限只能从小的范围到大的范围改变,例如,父类中的dosomething()方法的修饰权限为protected,继承后子类中的方法doSomething()的修饰权限只能修改为public,不能修改为private。

重写的规则:

(1)参数列表必须完全与被重写的方法相同,否则不能称其为重写而是重载。

(2)访问修饰符的限制一定要大于被重写方法的访问修饰符(public>protected>default>private)。

(3)重写方法一定不能抛出新的检查异常或者比被重写方法申明更加宽泛的检查型异常。例如:父类的一个方法申明了一个检查异常IOException,在重写这个方法是就不能抛出Exception,只能抛出IOException的子类异常,可以抛出非检查异常。

 

3、重构

重构:是重写的一种特殊方式,子类与父类的成员方法的返回值、方法名称、参数类型及个数完全相同,唯一不同的是方法实现内容,这种特殊重写方式被称为重构。

 

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

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

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


相关推荐

  • java命令行执行 jar_java命令打包jar

    java命令行执行 jar_java命令打包jar摘要这个技巧阐明了如何不直接处理清单文件而将一个不能运行jar包转换成一个可以执行的jar包。学会如何写一段转换jar包的程序,将你的jar包转换成你能使用java-jar命令运行jar包或象在windows系统上那样通过双击来运行jar包。你可以很容易地将一个应用的所有的类和资源打包到一个jar文件中去。事实上,这只是打包的一个原因。另一个原因是让用户很容易地执行包中的应用。那么在java的…

    2022年10月5日
    2
  • 网络爬虫必备知识之正则表达式

    1.正则表达式概念正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符、及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑。许多程序

    2021年12月29日
    47
  • hyper-v虚拟机安装xp系统网络不通_hyper-v转换vmware

    hyper-v虚拟机安装xp系统网络不通_hyper-v转换vmware下载一个ISO格式的XP系统镜像,把ISO文件设置为虚拟机的光驱,启动虚拟机,会自动从ISO镜像文件启动,创建虚拟机,创建虚拟磁盘VHD,然后加入启动项。打开本系统的磁盘管理,对虚拟磁盘进行格式化,并设置为活动分区(有一个就行)然后启动虚拟机,给虚拟机安装系统,就可以了。我是启动虚拟机后进入PE,然后选择Ghost32装的。如果启动虚拟机鼠标不能动,就点“

    2022年8月16日
    3
  • c语言 银行家算法(完整代码实现)

    c语言 银行家算法(完整代码实现)银行家算法例子:T0时刻进程P1提出需要(1、0、2)个资源的请求T0时刻进程P4提出需要(3、3、0)个资源的请求T0时刻进程P0提出需要(0、2、0)个资源的请求全局变量:intMax[5][3]={7,5,3,3,2,2,9,0,2,2,2,2,4,3,3};//五个进程对各种资源的最大需求intAllocation[5][3]={0,1,0,2,0,0,3,0,2,2,1,1,0,0,2};//五个进程已分配的各种资源数目intNeed[5][3]={7,4,3

    2022年5月7日
    59
  • axure菜单展开收起_css菜单栏的隐藏和显示

    axure菜单展开收起_css菜单栏的隐藏和显示这样可以实现菜单栏最小化,而且在你鼠标不移动到左上角时,小箭头会隐藏,效果就可以了。axure9.0版本在发布后HTML页面打开时总是在顶部弹出菜单既不美观也影响效果。本人axure小白,摸索半天后发现也不能完全关闭或者不显示(除非代码修改);解决方案就是在请求地址后面拼接。…

    2022年8月19日
    15
  • 变量,常量,静态变量存储的位置

    变量,常量,静态变量存储的位置常见的存储区域可分为:1、栈由编译器在需要的时候分配,在不需要的时候自动清楚的变量的存储区。里面的变量通常是局部变量、函数参数等。2、堆由new分配的内存块,他们的释放编译器不去管,由我们的应用程序去控制,一般一个new就要对应一个delete。如果程序员没有释放掉,程序会一直占用内存,导致内存泄漏,在程序结束后,操作系统会自动回收。3、自由存储区由malloc等分配的内存

    2022年6月11日
    42

发表回复

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

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