1.(多选题)给定java代码如下所示,在1处新增下列()方法,是对show()方法的重载

public class Test{
public void show(int x, int y, int z) { }
//
}

A.public int show(int x,int y,float z){return 0;}

B.public int show(int x,int y,int z){return 0;}

C.public void show(int x,int z){}

D.public viod show(int z,int y,int x){}

答案:AC

解析:本题考查方法的重载规则

方法的重载必须满足方法名相同和参数不同(类型或个数)

选项AC满足重载的条件,正确

选项BD参数都与定义的方法参数相同,不是重载。

2.(单选题)类A、B和C的定义如下:

public class A {
public void f() {
System.out.println("A.f()");
}
} public class B extends A {
public void f() {
System.out.println("B.f()");
}
} public class C {
public void g(A a) {
System.out.println("g(A a)");
a.f();
}
public void g(B b) {
System.out.println("g(B b)");
b.f();
}
}

运行下列程序:

C c = new C();
A e = new B();
c.g(e);

输出的结果是()

A. g(A a)  A.f()

B. g(A a) B.f()

C. g(B b) A.f()

D. g(B b) B.f()

答案:B

解析:C类中的两个方法是重载的方法,编译器会在编译时根据签名的不同来绑定调用不同的方法

A e =new B(); 这句是一个向上造型,e是A类的引用,但是指向的是B类的对象,而重载看的是参数的引用类型,重写才是看的对象类型

因为c调用的g方法参数是A类型的,所以匹配的是g(A a)的方法,先输出"g(A a)",然后执行a.f();

     A类和B类是父子类关系,两个f()是重写的方法,执行哪个方法类的方法要看具体的对象

而e指向的对象是B对象,所以找到B类中的f方法输出"B.f()"

也就是子类继承父类时,调用的方法都是子类重写后的方法

3.(多选题)请看下列代码

public class Tetromino {
protected int move(int x) {
return 0;
}
}
class T extends Tetromino {
<插入代码>
}

在<插入代码>处填入选项中的代码,使T类没有编译错误的是()

A.public int move(int x) { return 0; }

B.private int move(int x) { return 0; }

C.private int move(long x) { return 0; }

D.protected long move(int x) { return 0; }

答案:AC

解析: 本题考查方法的重写和重载语法。

    注:方法的重写要遵循“两同两小一大”规则,“两同”即方法名相同,形参列表相同;“两小”指的是子类方法返回值类型应比父类方法返回值类型更小或相等;子类方法声明抛出的异常类应比父类方法声明抛出的异常类更小或相等;“一大”指的是子类方法的访问权限应比父类方法的访问范围更大或相等。

   选项A,符合重写的定义,A选项正确。

   选项B,不符合重写也不符合重载的语法(访问权限为private小于父类的protected,不满足重写;参数列表相同,不满足重载),B选项错误。

   选项C,符合重载的语法,子类T继承父类Tetromino的 protected int move(int x) 方法,而C选择属于对重写方法的重载,所以C选择正确。

   选项D,不符合重写也不符合重载的语法(返回值类型为long,与父类的int不同,不满足重写;参数列表相同,不满足重载),D选项错误

每日笔记:

重写和重载有什么区别?重写的两同两小一大规则是什么?

  Overload是重载的意思,Override是覆盖的意思,也就是重写。

  重载Overload表示同一个类中可以有多个名称相同的方法,但这些方法的参数列表各不相同(即参数个数或类型不同)。

  重写Override表示子类中的方法可以与父类中的某个方法的名称和参数完全相同,通过子类创建的实例对象调用这个方法时,将调用子类中的定义方法,这相当于把父类中定义的那个完全相同的方法给覆盖了,这也是面向对象编程的多态性的一种表现。

  重写要遵循"两同两小一大"原则:

  两同:1)方法名相同 2)参数列表相同

  两小: 1)子类方法的返回值类型小于或等于父类的

       1.1)void时必须相等

      1.2)基本类型时必须相等

    1.3)引用类型时小于或相等:父类大,子类小

    2)子类抛出的异常小于或等于父类的

  一大:子类方法的访问权限大于或等于父类的

Java基础练习3(重载和重写)的更多相关文章

  1. Java基础(七):重写与重载

    一.重写(Override): 重写是子类对父类的允许访问的方法的实现过程进行重新编写, 返回值和形参都不能改变.即外壳不变,核心重写! 重写的好处在于子类可以根据需要,定义特定于自己的行为. 也就是 ...

  2. Java中函数的重载和重写

    重载 重载指的是两个或者两个以上同名函数,但它们的参数不一样,这时会出现函数重载的情况.比如下面这段代码 class Test{ public void a(){ System.out.println ...

  3. 【Java】方法的重载与重写

    一.方法的重载 1.概念 方法重载是指在一个类中定义多个同名的方法,但要求每个方法具有不同的参数的类型或参数的个数. 调用重载方法时,Java编译器能通过检查调用的方法的参数类型和个数选择一个恰当的方 ...

  4. 如何区分Java中的方法重载和重写

    首先说的是重载: 方法的重载 * 在同一个类中,方法名相同,参数列表不同.与返回值类型无关. * 参数列表不同: * A:参数个数不同 * B:参数类型不同 * C:参数的顺序不同(不算重载 报错) ...

  5. java中的方法——重载yu重写(转)

    重载(Overloading) (1) 方法重载是让类以统一的方式处理不同类型数据的一种手段.多个同名函数同时存在,具有不同的参数个数/类型. 重载Overloading是一个类中多态性的一种表现. ...

  6. 详细讲解Java中方法的重载和重写

    首先讲讲方法的重载: Java的重载就是在类中可以创建多个方法,它们具有相同的名字,但是却有不同的参数. 判断是否重载只有两个条件: 1)相同的方法名 2)不同的参数 具体为: A.方法参数类型不同 ...

  7. Java中方法的重载与重写

    1.方法的名字和参数列表称为方法的签名:每个方法具有唯一与其对应的签名: 2.方法的重载:在某个类中,存在具有多个相同名字不同参数列表的方法,称之为重载: 被重载的方法必须改变参数列表(参数个数或类型 ...

  8. java中的方法重载与重写以及方法修饰符

    1. 方法重载Overloading , 是在一个类中,有多个方法,这些方法的名字相同,但是具有不同的参数列表,和返回值 重载的时候,方法名要一样,但是参数类型和参数个数不一样,返回值类型可以相同,也 ...

  9. Java基础(8):方法重载的4个依据与例子

    判断方法重载的依据: 1. 必须是在同一个类中 2. 方法名相同 3. 方法参数的个数.顺序或类型不同 4. 与方法的修饰符或返回值没有关系 运行结果:

随机推荐

  1. HTTP协议、Ajax请求

    今天这篇文章呢,主要讲的就是关于HTTP协议.Ajax请求以及一些相关的小知识点.虽然内容不算多,可是是很重点的东西~ HTTP协议 1. http:超文本传输协议.简单.快速.灵活.无状态.无连接. ...

  2. redis的持久化之RDB的配置和原理

    Redis优秀的性能是由于其将所有的数据都存储在内存中,同样memcached也是这样做的,内存中的数据会在服务器重启后就没有了,也就是不能保证持久化.但是为什么Redis能够脱颖而出呢,很大程度上是 ...

  3. .net Core 微服务框架 surging 使用

    surging 是一个分布式微服务框架,提供高性能RPC远程服务调用,采用Zookeeper.Consul作为surging服务的注册中心, 集成了哈希,随机,轮询作为负载均衡的算法,RPC集成采用的 ...

  4. SpringCloud实战-Hystrix线程隔离&请求缓存&请求合并

    接着上一篇的Hystrix进行进一步了解. 当系统用户不断增长时,每个微服务需要承受的并发压力也越来越大,在分布式环境中,通常压力来自对依赖服务的调用,因为亲戚依赖服务的资源需要通过通信来实现,这样的 ...

  5. linux内核堆栈

    一:进程的堆栈 内核在创建进程的时候,在创建task_struct的同时会为进程创建相应的堆栈.每个进程会有两个栈,一个用户栈,存在于用户空间,一个内核栈,存 在于内核空间.当进程在用户空间运行时,c ...

  6. SpringMVC表当重复提交

    最近公司上线,有同志进行攻击,表当防重复提交也没有弄,交给我 ,本人以前也没弄过,知道大概的思路,但是那样实在是太麻烦了,虽然后面试过使用过滤器加拦截器实现,不过还是有点小麻烦. 后来在网上搜索后发现 ...

  7. linux内核中断之看门狗

    一:内核中断 linux内核中的看门狗中断跟之前的裸板的中断差不多,在编写驱动之前,需要线把内核自带的watch dog模块裁剪掉,要不然会出现错误:在Device Drivers /Watchdog ...

  8. 解决fatal error LNK1168的终极方法

    很多人的VC++或Visual studio 会出现fatal error LNK1168错误很是头疼,MS也说不清, 什么改权限.用户名.注册表.CMD,卸载杀毒软件...一切都瞎扯,除非reins ...

  9. 第八章——降维(Dimensionality Reduction)

    机器学习问题可能包含成百上千的特征.特征数量过多,不仅使得训练很耗时,而且难以找到解决方案.这一问题被称为维数灾难(curse of dimensionality).为简化问题,加速训练,就需要降维了 ...

  10. InnoDB基本特性

    Ⅰ.double write 目的:保证数据写入的可靠性 小知识: 什么是partial write? 16k的page只写入了4k,6k,8k,12k就断掉了的情况 corrupt的page就是pa ...