class FatherA{ int x,y; FatherA(int x,int y){this.x=x;this.y=y;} static void show(){ System.out.println("FatherA静态方法"); } void compare(){ System.out.println(x+y); } } class SonB extends FatherA{ int x,y; Son

时间: 2023-12-01 07:03:49 浏览: 29
B(int x,int y,int a,int b){ super(x,y); this.x=a; this.y=b; } static void show(){ System.out.println("SonB静态方法"); } void compare(){ super.compare(); System.out.println(x+y); } } 以上是一个Java代码,其中FatherA是父类,SonB是子类。 父类和子类都有x和y属性,但是子类中的x和y是新定义的,与父类中的x和y不同。 父类中有一个compare()方法,输出x和y的和,而子类中也有一个compare()方法,先调用父类的compare()方法,再输出子类中的x和y的和。 父类中有一个静态方法show(),输出"FatherA静态方法",而子类中也有一个静态方法show(),输出"SonB静态方法",这种情况下,当通过子类调用静态方法show()时,输出的是"SonB静态方法",而不是"FatherA静态方法"。
相关问题

解释下面这段代码并输出值class FatherA{ int x,y; FatherA(int x,int y){this.x=x;this.y=y;} static void show(){ System.out.println("FatherA静态方法"); } void compare(){ System.out.println(x+y); } } class SonB extends FatherA{ int x,y; SonB(int x,int y) { super(x,y);//代码1 this.x=x; this.y=y; } void compare(){ System.out.println(x+y); } static void show(){ System.out.println("SonB类的静态方法"); } } public class Test { public static void main(String[] args) { FatherA a; SonB b=new SonB(10,20); a=b; b.compare();//代码2 a.compare();//代码3 b.show();//代码4 a.show();//代码5 } }

以上代码定义了一个父类FatherA和一个子类SonB,SonB是FatherA的子类。在Test类的main方法中,创建了一个SonB对象b,并将其赋值给FatherA类型的变量a。 在代码行1中,FatherA类有一个构造函数,用于初始化父类的成员变量x和y,使用this关键字来指代当前对象。 在代码行3中,FatherA类有一个静态方法show(),输出"FatherA静态方法"。 在代码行4中,FatherA类有一个实例方法compare(),输出x+y的值。 在代码行5中,SonB类继承了FatherA类,并且添加了自己的成员变量x和y。在SonB类的构造函数中,使用super关键字调用父类的构造函数,初始化父类的成员变量x和y,然后使用this关键字初始化子类的成员变量x和y。 在代码行8中,SonB类重写了compare()方法,输出子类自己的x+y的值。 在代码行9中,SonB类有一个静态方法show(),输出"SonB类的静态方法"。 在代码行12中,b.compare()输出30,因为子类的compare()方法被调用,输出子类自己的x+y的值。 在代码行13中,a.compare()输出30,因为a指向的是一个SonB对象,调用的是子类的compare()方法,输出子类自己的x+y的值。 在代码行14中,b.show()输出"SonB类的静态方法",因为调用的是子类的静态方法show()。 在代码行15中,a.show()输出"FatherA静态方法",因为静态方法不具有多态性,调用的仍然是父类的静态方法show()。

解释下面这段代码class FatherA{ int x,y; FatherA(int x,int y){this.x=x;this.y=y;} static void show(){ System.out.println("FatherA静态方法"); } void compare(){ System.out.println(x+y); } } class SonB extends FatherA{ int x,y; SonB(int x,int y) { super(x,y);//代码1 this.x=x; this.y=y; } void compare(){ System.out.println(x+y); } static void show(){ System.out.println("SonB类的静态方法"); } } public class Test { public static void main(String[] args) { FatherA a; SonB b=new SonB(10,20); a=b; b.compare();//代码2 a.compare();//代码3 b.show();//代码4 a.show();//代码5 } }

这段代码定义了一个父类 FatherA 和一个子类 SonB,其中 SonB 继承自 FatherA。在 main 方法中,创建了一个 SonB 对象 b,并将其赋值给 FatherA 类型的变量 a。 代码1中使用 super 调用了父类的构造方法,初始化了父类的 x 和 y 字段。同时,子类也有自己的 x 和 y 字段。 代码2和代码3分别调用了子类和父类的 compare 方法。由于子类重写了父类的 compare 方法,因此代码2输出的是子类的 x+y 的结果,而代码3输出的是父类的 x+y 的结果。 代码4和代码5分别调用了子类和父类的静态方法 show。静态方法是不受对象影响的,因此无论是调用子类的静态方法还是父类的静态方法,输出的都是对应类中定义的静态方法的内容。因此,代码4输出的是 SonB 类的静态方法的内容,而代码5输出的是 FatherA 类的静态方法的内容。注意,子类的静态方法不能重写父类的静态方法,因此代码4中的 SonB 类的静态方法并没有覆盖 FatherA 类的静态方法。

相关推荐

帮我修改下面这个代码:#include <iostream> #include <queue> using namespace std; struct Node { int number; int father; int floor; bool bl = false; }; class dls { private: int n; Node* node; int** map; public: dls(int n):n(n){} void Map()//建立邻接矩阵的下三角并初始化 { map = new int* [n]; for (int i = 0; i < n; i++) map[i] = new int[i + 1]; for (int i = 0; i < n; i++) for (int j = 0; j <= i; j++) map[i][j] = 0; } void createGraph()//对邻接矩阵进行赋值 { cout << "请输入村庄的" << n - 1 << "条道路:" << endl; node = new Node[n]; for (int i = 0; i < n; i++) node[i].number = i; for (int i = 0; i < n - 1; i++) { int x, y; cin >> x >> y; if (x >= y) map[x][y] = 1; else map[y][x] = 1; } } void BFSTree()//利用BFS建立树 { queue<int>qu; qu.push(0); node[0].father = 0; node[0].floor = 0; node[0].bl = true; while (!qu.empty()) { int x = qu.front(); qu.pop(); for (int i = 0; i < n; i++) { if (map[x][i] == 1 || map[i][x] == 1 && node[i].bl = false) { node[i].bl = true; node[i].father = x; node[i].floor = node[x].floor + 1; qu.push(i); } } } } int findFather(int m,int n)//寻找父亲结点 { int my_m = m; int my_n = n; int gap; if (node[m].floor > node[n].floor) { gap = node[m].floor - node[m].floor; for (int i = 0; i < gap; i++) my_m = node[m].father; } else { gap = node[n].floor - node[m].floor; for (int i = 0; i < gap; i++) my_n = node[n].father; } while (my_m != my_n) { my_m = node[m].father; my_n = node[n].father; } return m; } }; int main() { int T; int N; int M; cout << "请输入需要测试的组数:"; cin >> T; while (T--) { cout << "请输入村庄个数:"; cin >> N; dls ddd(N); ddd.Map(); ddd.createGraph(); ddd.BFSTree(); cout << "请输入需要测试的问题数:"; cin >> M; for (int i = 1; i <= M; i++) { int a, b, c; cout << "请依次输入abc的编号: "; cin >> a >> b >> c; int ab = ddd.findFather(a, b); int ac = ddd.findFather(a, c); int bc = ddd.findFather(b, c); if (ac == c && bc == c && ab == c) cout << "Yes" << endl; else if (ac == c && bc != c) cout << "Yes" << endl; else if (bc == c && ac != c) cout << "Yes" << endl; else cout << "No" << endl; } } return 0; }

docx

最新推荐

recommend-type

2024嵌入式大厂面经CVTE

2024嵌入式大厂面经CVTE提取方式是百度网盘分享地址
recommend-type

掺工业废钛石膏制备自密实混凝土研究

虽然自密实混凝土作为目前建筑领域应用最广泛的材料,但是由于其性能等方面的局限性,导致了目前普通自密实混凝土难以满足不断提高的工程建设要求。研究发现, 通过在自密实混凝土中添加钛石膏等可以验证混凝土各方面性能的提高。且向自密实混凝土中添加工业废钛石膏,将其应用于建材领域,不仅可以解决目前市场上对自密实混凝土的运用问题,还能改善环境及固体废弃物综合利用的问题。因此开展对掺工业废钛石膏制备自密实混凝土的研究。 在本文中,我们对掺工业废钛石膏制备自密实混凝土静力学性能做了系统性试验,对于掺工业废钛石膏制备自密实混凝土中钛石膏质量份数,我们采用的是 85 份、90 份和 95 份。整个试验可分为两个部分:一、单轴压缩试验和巴西圆盘劈裂抗拉试验,通过这两个试验主要得出钛石膏自密实混凝土的抗压强度、弹性模量与劈裂抗拉强度;二、不同粉料配比对掺工业废钛石膏制备自密实混凝土的影响,通过对不同粉料制成的掺工业废钛石膏制备自密实混凝土的坍落扩展度和离析率影响试验。最后分析试验数据,从而得出本文结论。 本文通过对大量试验数据的总结与分析,结合国内外相关研究的已有结论, 总结出当工业废钛石膏质量份数增加到
recommend-type

2024年家庭农场市场趋势分析.pptx

行业报告
recommend-type

DirectShow过滤器-AAC编码器

本过滤器将PCM音频流编码为AAC音频流,由输出引脚输出。 参见介绍文章:https://blog.csdn.net/h3974/article/details/139550603?csdn_share_tail=%7B%22type%22%3A%22blog%22%2C%22rType%22%3A%22article%22%2C%22rId%22%3A%22139550603%22%2C%22source%22%3A%22h3974%22%7D 过滤器名称:AAC编码器 过滤器GUID:{59FB3C29-4C37-47D9-AA73-1DFEDC0DDF71} 过滤器有1个输入引脚和1个输出引脚。 输入引脚 标识:In 媒体类型: 主要类型:MEDIATYPE_Audio 子类型:MEDIASUBTYPE_PCM 格式类型:FORMAT_WaveFormatEx 输出引脚 标识:Out 媒体类型: 主要类型:MEDIATYPE_Audio 子类型:MEDIASUBTYPE_MPEG_HEAAC 格式类型:FORMAT_WaveFormatEx
recommend-type

电商平台用户行为分析与可视化数据集.zip

电商平台用户行为分析与可视化数据集
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB正态分布协方差分析:揭示正态分布变量之间的协方差

![MATLAB正态分布协方差分析:揭示正态分布变量之间的协方差](https://site.cdn.mengte.online/official/2021/11/20211128213137293.png) # 1. 正态分布概述 正态分布,又称高斯分布,是统计学中最重要的连续概率分布之一。它广泛应用于自然科学、社会科学和工程领域。 正态分布的概率密度函数为: ``` f(x) = (1 / (σ√(2π))) * exp(-(x - μ)² / (2σ²)) ``` 其中: - μ:正态分布的均值 - σ:正态分布的标准差 - π:圆周率 正态分布具有以下特性: - 对称性:
recommend-type

我正在开发一款个人碳足迹计算app,如何撰写其需求分析文档,请给我一个范例

为了更全面、清晰地定义个人碳足迹计算app的需求,需求分析文档应该包含以下内容: 1.项目简介:对该app项目的概述及目标进行说明。 2.用户分析:包括目标用户群、用户需求、行为等。 3.功能需求:对app的基本功能进行定义,如用户登录、数据录入、数据统计等。 4.非功能需求:对使用app的性能和质量等进行定义,如界面设计、数据安全、可扩展性等。 5.运行环境:包括app的开发环境和使用环境。 下面是一个范例: 需求分析文档 1. 项目简介 该app项目旨在为用户提供一款方便、易用、可定制的个人碳足迹计算平台,以促进环保和可持续性发展。 2. 用户分析 目标用户群:全球关
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。