1)定义Student类,用string型变量name存储学生姓名,用int型变量age存储学生年龄。Student类实现IComparable接口。要求从键盘输入学生的姓名和年龄,并注意可能出现的异常及其处理。IComparable接口定义如下(系统已定义,可直接使用)

interface IComparable

{

int CompareTo(object obj);

//如果自身与obj相等返回0,<obj返回-1,>obj返回1 ,注意可能出现的异常

}

(2)定义Student类的派生类Master。

(3)定义Sort类,定义静态方法BubbleSortDescending(IComparable[] bubbles),实现对象的降序排列。其中,在该方法中调用接口方法CompareTo(object obj)比较两个对象的“大小”。

(4)定义Test类,按给定数据生成Student实例数组,调用BubbleSortDescending(IComparable[] bubbles)使之按姓名排序,按给定数据生成Master实例数组,调用BubbleSortDescending(IComparable[] bubbles)使之按年龄排序,请遍历输出排序前后数组中每个元素实例中的name和age。如果Master实例a与Student实例b比较,总是a>b

(5)实验数据

Name

Age

Tom

Nick

Mike

(a)当这三个学生全为Student的实例时,输出排序后的结果;

(b)当这三个学生全为Master类的实例时,输出排序后的结果

(c)(选作)任意指定数组中元素的类型(Student或Master),输出排序后的结果

(6)分析并解释实验结果。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace Q4
{
interface IComparable
{
int CompareTo(object obj);
} class Student : IComparable
{
string name;
int age;
public Student(string name, int age)
{
this.name = name;
this.age = age; } public virtual int CompareTo(object obj)//对接口的方法进行重写
{
Student other = (Student)obj;
if (other != null)
{
if (string.Compare(name,other.Name)<0) return 1;
else if (string.Compare(name, other.name) == 0) return 0;
else return -1;
}
else
throw new ArgumentException("Object is not a Student");
}
public string Name
{
get
{
return name;
}
} public int Age
{
get
{
return age;
}
}
} class Master : Student
{
string name;
int age;
public Master(string name, int age) : base(name, age)
{
this.name = name;
this.age = age;
}
public override int CompareTo(object obj)//override 对student里的compareto方法进行重写
{
Master other = (Master)obj;//强制类型转换
if (other!= null)//判断是否空,异常
{
if (age < other.Age) return 1;
else if (age == other.Age) return 0;
else return -1;
}
else
throw new ArgumentException("Object is not a Master");
} public new string Name
{
get
{
return name;
}
} public new int Age
{
get
{
return age;
}
}
} class Sort
{
static IComparable g;//在静态函数里面的变量也要用静态
public static void BubbleSortDescending(IComparable[] bubbles)
//因为这里student类继承icomparable,而master继承student,所以这里要用ICmparable
{
for (int i = 0; i < bubbles.Length - 1; i++)
{
if (bubbles[i].CompareTo(bubbles[i + 1]) > 0)
{
g = bubbles[i];
bubbles[i] = bubbles[i + 1];
bubbles[i + 1] = g; }
}
}
} class Test
{
static void Main(string[] args)
{
IComparable[] a = new Student[3];//用了多态,因为Student继承IComparable,所以可以这样写
a[0] = new Student("Tom", 18);//c初始化,也是要用new
a[1] = new Student("Nike", 20);
a[2] = new Student("Mike", 17);
Sort.BubbleSortDescending(a);
foreach(Student b in a )//a是数组名所以直接 in a
{
Console.WriteLine("{0}----{1}", b.Name, b.Age);
} Master[] c = new Master[3];
c[0] = new Master("Tom", 18);
c[1] = new Master("Nike ", 20);
c[2] = new Master("Mike", 17);
Sort.BubbleSortDescending(c);
Console.WriteLine();
foreach(Master d in c)
{
Console.WriteLine("{0}----{1}", d.Name, d.Age);
} }
}
}

c#接口与虚函数的实验报告的更多相关文章

  1. C#虚函数和接口的区别

    接口只能声明不能实现,虚函数可以. 接口:对外提供可以访问的函数叫接口.虚函数不需要被强制重写,其本身含有实现部分. 抽象类:指派了派生类必须实现的函数(纯虚函数),不然编译不通过. 虚函数的限制:  ...

  2. 关于C++与Java中虚函数问题的读书笔记

    之前一直用C++编程,对虚函数还是一些较为肤浅的理解.可近期由于某些原因搞了下Java,发现有些知识点不熟,于是站在先驱巨人的肩上谈谈C++与Java中虚函数问题. Java中的虚函数 以下是段别人的 ...

  3. C++回顾day03---<纯虚函数和抽象类以及虚析构函数,delete使用>

    一:纯虚函数和抽象类 纯虚函数是一个在基类中说明的虚函数,在基类中没有定义,要求任何派生类都定义自己的版本 纯虚函数为各个派生类提供一个公共接口 纯虚函数的形式: virtual 类型 函数名(参数列 ...

  4. c++ 多态,虚函数、重载函数、模版函数

    c++三大特性:封装.继承.多态.封装使代码模块化,继承扩展已存在的代码,多态的目的是为了接口重用 虚函数实现:虚函数表:指针放到虚函数表 多态:同名函数对应到不同的实现 构造父类指针指向子类的对象 ...

  5. why pure virtual function has definition 为什么可以在基类中实现纯虚函数

    看了会音频,无意搜到一个frameworks/base/include/utils/Flattenable.h : virtual ~Flattenable() = 0; 所以查了下“纯虚函数定义实现 ...

  6. 第八周课程总结 & 实验报告(六)

    第八周课程总结 一.包装类 介绍 装箱与拆箱 应用 二.异常 基本概念 基本格式 异常类的继承结构 throws关键字 throw关键字 Exception类和RuntimeException类 自定 ...

  7. c# 基础(重写与覆盖:接口与抽象,虚函数与抽象函数)

    总结 1:不管是重写还是覆盖都不会影响父类自身的功能(废话,肯定的嘛,除非代码被改). 2:当用子类创建父类的时候,如 C1 c3 = new C2(),重写会改变父类的功能,即调用子类的功能:而覆盖 ...

  8. C# 类的多态、结构、接口、抽象、虚函数总结

    多态: 类的多态是通过在子类(派生类)中重载基类的虚方法或成员函数来实现的. 可见,重载和虚函数的重写,并在调用时用父类装箱子类对象,是实现多态的一种重要的编程方式. 接口: 接口是一种用来定义程序的 ...

  9. JAVA – 虚函数、抽象函数、抽象类、接口

     本文转载地址:http://blog.csdn.net/trojanpizza/article/details/6556604 1. Java虚函数 虚函数的存在是为了多态. C++中普通成员函数加 ...

随机推荐

  1. NOI2019冬令营报到通知

    由中国计算机学会(CCF)主办的2019全国青少年信息学奥林匹克冬令营(CCF NOI 2019冬令营)将于2019年1月24日-31日在广州市第二中学举行.其中1月24日为报到日,1月31日为疏散日 ...

  2. pyhton 学习 函数式编程

    函数是python内建支持的一种封装,我们通过把打断的代码拆成函数,通过一层一层的函数调用,就可以把复杂任务分解成简单的任务,这种分解可以称之为面向过程的程序设计,函数就是面向过程的程序设计的基本单元 ...

  3. 软件设计基础-C/S系统

    在软件设计开发过程中,逐渐形成了一些针对特定应用领域的软件系统组织方式的惯用模式 如经典的C/S(client/server,客户/服务器)模式和B/S(browser/server,浏览器/服务器) ...

  4. [Linux]Linux下开启snmp支持IPV4和IPV6

    SNMP简介 简单网络管理协议(SNMP),由一组网络管理的标准组成,包含一个应用层协议(application layer protocol).数据库模型(database schema)和一组资源 ...

  5. tf.nn.conv2d

    tf.nn.conv2d(input, filter, strides, padding, use_cudnn_on_gpu=None, name=None) input: 指需要做卷积的输入图像,它 ...

  6. http协议相关

    HTTP请求方法 HTTP消息头 HTTP请求头 HTTP响应头 HTTP cookie机制和实现原理 HTTP请求方法 超文本传输协议(HTTP, HyperText Transfer Protoc ...

  7. Python 实例变量

    class Person: def __init__(self, name, id, gender, birth): self.name = name # 实例变量 对象里的变量 self.id = ...

  8. 在Ubuntu上搭建IntelliJ IDEA license server服务器

    1.下载激活文件 2.ubuntu需要使用 IntelliJIDEALicenseServer_linux_amd64 ,把该文件传到服务器的某个目录,我是放在了/jideal 下 3.进入上面的目录 ...

  9. JAVA线程sleep与wait区别

    sleep就是正在执行的线程主动让出cpu,cpu去执行其他线程,在sleep指定的时间过后,cpu才会回到这个线程上继续往下执行,如果当前线程进入了同步锁,sleep方法并不会释放锁,即使当前线程使 ...

  10. Popover 弹出框 设置top,显示有时是向下的,解决方式

    参数里面有个popper-options,官网给的值是{boundariesElement: 'body', gpuAcceleration: false },将这个加上问题就解决了.