抽象类、虚函数、接口、多态 概念与关系的理解

本文详细解释了抽象类、虚方法及接口的概念与用法,包括它们在多态中的角色,以及如何选择使用抽象类、虚方法或接口。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

抽象类: (abstract)
不能实例化。
可以在抽象类中定义抽象方法,以供派生类写具体方法。
派生类也可以保留抽象方法,但该类必须为抽象类。
也可以在抽象类中写非抽象方法。
例子:
抽象类
public abstract class AbstractClass
{
    public abstract string GetName(string Name);
    public string GetNameByID(string Name)
    {
        return Name;
    }
}
派生类
public class UserClass:AbstractClass
{
    public override string GetName(string Name)
    {
        return Name + "nihao.";
    }
}

虚方法: (virtual)
通过在基类中定义虚方法(virtual),在子类中,可以通过override进行派生重写。
例子
基类
public class VirtualClass
{
    public virtual string GetName(string Name)
    {
        return Name;
    }
}
子类
public class UserClass2:VirtualClass
{
    public override string GetName(string Name)
    {
        //return base.GetName(Name);
        return "Hello." + Name;
    }
}

接口: (interface)
接口即契约。用于规定一种规则由大家遵守。允许多继承.而继承类只允许单继承.
定义接口
public interface UserInterface
{
    void UserLogin(string UserName,string Password);
    bool Login(out string exInfo);
}
使用接口
public class UserClass : UserInterface
{
    #region UserInterface 成员
    public void UserLogin(string UserName, string Password)
    {
        throw new Exception("The method or operation is not implemented.");
    }
    public bool Login(out string exInfo)
    {
        throw new Exception("The method or operation is not implemented.");
    }
    #endregion
}

说明:

多态是面向对象编程的三大特性之一。
接口和虚函数是多态的表现形式。
在需要多态的情境下:

如果类中方法可以确定下来,而以后可能改变方法的用途,使用虚函数较好。
如果类中方法不确定,用途也不确定。只能确定格式,那么使用接口,以方便需要的类进行继承。进行扩展。
抽象类不能多态。抽象类是用于在开发初期不清楚或者不确定后续方法细则的情况下使用。

虚函数是一个已经定义好的函数,可以直接使用。
接口只是定义契约,没有具体实现。必须继承后实现才能使用。
接口本质上仍然被标记为.class,同时提供abstract virtual 方法的Method,因此接口其实本质上可以看作是一个定义了抽象方法的类,该类仅提供了方法的定义,而没有方法的实现,其功能由接口的实现类来完成。

虚函数可以在抽象类和非抽象类中定义,而抽象方法必须在抽象类中定义。
抽象类中的非抽象方法,在派生的类中,不能重写。


还不明白请看下面:
  interface用来声明接口
  1.只提供一些方法规约,不提供方法主体
  如:   public interface IPerson
  ...{
       void getName(); //不包含方法主体
  }

  2.方法不能用public abstract等修饰,无字段变量,无构造函数。

  3.方法可包含参数
  如:   public interface IPerson
  ...{
       void getAge(string s);
  }

  如下,举一个例子(例1):   public interface IPerson
  ...{
       IPerson(); //错误
       string name; //错误
       public void getIDcard();//错误
       void getName(); //right
       void getAge(string s); //right
  }

  实现interface的类
  1.与继承类的格式一致,如 public class Chinese:IPerson{}
  2.必须实现interface中的各个方法
  例2,继承例1
  public class Chinese:IPerson
  ...{
       public Chinese()...{} //添加构造
       public void getName()...{} //实现getName()
       public void getAge(string s)...{} //实现getAge()
  }
  abstract声明抽象类、抽象方法
  1.抽象方法所在类必须为抽象类
  2.抽象类不能直接实例化,必须由其派生类实现。
  3.抽象方法不包含方法主体,必须由派生类以override方式实现此方法,这点跟interface中的方法类似
  如:
  public abstract class Book
  ...{
       public Book()
       ...{
       }

       public abstract void getPrice(); //抽象方法,不含主体
  
       public virtual void getName() //虚方法,可覆盖
       ...{
            Console.WriteLine("this is a test:virtual getName()");
       }
  
       public virtual void getContent() //虚方法,可覆盖
       ...{
            Console.WriteLine("this is a test:virtual getContent()");
       }
  
       public void getDate() //一般方法,若在派生类中重写,须使用new关键字
       ...{
            Console.WriteLine("this is a test: void getDate()");
       }
  }

  public class JavaBook:Book
  ...{
       public override void getPrice() //实现抽象方法,必须实现
       ...{
            Console.WriteLine("this is a test:JavaBook override abstract getPrice()");
       }

       public override void getName() //覆盖原方法,不是必须的
       ...{
            Console.WriteLine("this is a test:JavaBook override virtual getName()");
       }
  }
  测试如下:
  public class test
  ...{
       public test()
       ...{
            JavaBook jbook=new JavaBook();
            jbook.getPrice(); //将调用JavaBook中getPrice()
            jbook.getName(); //将调用JavaBook中getName()
            jbook.getContent(); //将调用Book中getContent()
            jbook.getDate(); //将调用Book中getDate()
       }

       public static void Main()
       ...{
            test t=new test();
       }
  }
  virtual标记方法为虚方法
  1.可在派生类中以override覆盖此方法
  2.不覆盖也可由对象调用
  3.无此标记的方法(也无其他标记),重写时需用new隐藏原方法
  abstract与virtual: 方法重写时都使用 override 关键字
  interface中的方法和abstract方法都要求实现

new override 关于
内容概要:本文深入探讨了Kotlin语言在函数式编程和跨平台开发方面的特性和优势,结合详细的代码案例,展示了Kotlin的核心技巧和应用场景。文章首先介绍了高阶函数和Lambda表达式的使用,解释了它们如何简化集合操作和回调函数处理。接着,详细讲解了Kotlin Multiplatform(KMP)的实现方式,包括共享模块的创建和平台特定模块的配置,展示了如何通过共享业务逻辑代码提高开发效率。最后,文章总结了Kotlin在Android开发、跨平台移动开发、后端开发和Web开发中的应用场景,并展望了其未来发展趋势,指出Kotlin将继续在函数式编程和跨平台开发领域不断完善和发展。; 适合人群:对函数式编程和跨平台开发感兴趣的开发者,尤其是有一定编程基础的Kotlin初学者和中级开发者。; 使用场景及目标:①理解Kotlin中高阶函数和Lambda表达式的使用方法及其在实际开发中的应用场景;②掌握Kotlin Multiplatform的实现方式,能够在多个平台上共享业务逻辑代码,提高开发效率;③了解Kotlin在不同开发领域的应用场景,为选择合适的技术栈提供参考。; 其他说明:本文不仅提供了理论知识,还结合了大量代码案例,帮助读者更好地理解和实践Kotlin的函数式编程特性和跨平台开发能力。建议读者在学习过程中动手实践代码案例,以加深理解和掌握。
内容概要:本文深入探讨了利用历史速度命令(HVC)增强仿射编队机动控制性能的方法。论文提出了HVC在仿射编队控制中的潜在价值,通过全面评估HVC对系统的影响,提出了易于测试的稳定性条件,并给出了延迟参数跟踪误差关系的显式不等式。研究为两轮差动机器人(TWDRs)群提供了系统的协调编队机动控制方案,并通过9台TWDRs的仿真和实验验证了稳定性和综合性能改进。此外,文中还提供了详细的Python代码实现,涵盖仿射编队控制类、HVC增强、稳定性条件检查以及仿真实验。代码不仅实现了论文的核心思想,还扩展了邻居历史信息利用、动态拓扑优化和自适应控制等性能提升策略,更全面地反映了群体智能协作和性能优化思想。 适用人群:具备一定编程基础,对群体智能、机器人编队控制、时滞系统稳定性分析感兴趣的科研人员和工程师。 使用场景及目标:①理解HVC在仿射编队控制中的应用及其对系统性能的提升;②掌握仿射编队控制的具体实现方法,包括控制器设计、稳定性分析和仿真实验;③学习如何通过引入历史信息(如HVC)来优化群体智能系统的性能;④探索中性型时滞系统的稳定性条件及其在实际系统中的应用。 其他说明:此资源不仅提供了理论分析,还包括完整的Python代码实现,帮助读者从理论到实践全面掌握仿射编队控制技术。代码结构清晰,涵盖了从初始化配置、控制律设计到性能评估的各个环节,并提供了丰富的可视化工具,便于理解和分析系统性能。通过阅读和实践,读者可以深入了解HVC增强仿射编队控制的工作原理及其实际应用效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值