F# - 类继承

F# - 类继承 首页 / F#入门教程 / F# - 类继承

面向对象编程中最重要的概念之一就是继承,继承使无涯教程可以用另一个类来定义一个类,这使创建和维护应用程序变得更加容易,这也提供了重用代码功能和快速实现时间的机会。

创建类时,程序员可以指定新类应继承现有类的成员,而不必编写全新的数据成员和成员函数。此现有类称为基类,而新类称为子类。

基类和子类

子类继承基类的成员,并拥有自己的成员,子类使用 inherit 关键字定义,如下所示-

无涯教程网

type MyDerived(...) =
   inherit MyBase(...)

在F#中,一个类最多可以有一个直接基类,如果未使用 inherit 关键字指定基类,则该类隐式继承自对象(Object)。

type Person(name) =
   member x.Name = name
   member x.Greet() = printfn "Hi, I'm %s" x.Name

type Student(name, studentID : int) =
   inherit Person(name)
   let mutable _GPA = 0.0
   member x.StudentID = studentID
   member x.GPA
      with get() = _GPA
      and set value = _GPA <- value

type Teacher(name, expertise : string) =
   inherit Person(name)

   let mutable _salary = 0.0
   member x.Salary
      with get() = _salary
      and set value = _salary <- value
   member x.Expertise = expertise

//using the subclasses
let p = new Person("Mohan")
let st = new Student("Zara", 1234)
let tr = new Teacher("Mariam", "Java")

p.Greet()
st.Greet()
tr.Greet()

编译并执行程序时,将产生以下输出-

Hi, I'm Mohan
Hi, I'm Zara
Hi, I'm Mariam

覆盖方法

F#中的方法默认情况下不可覆盖。

要覆盖派生类中的方法,您必须使用 abstractdefault 关键字将方法声明为可覆盖,如下所示:

type Person(name) =
   member x.Name=name
   abstract Greet : unit -> unit
   default x.Greet()=printfn "Hi, I'm %s" x.Name

现在,可以在派生类中覆盖Person类的 Greet 方法。以下示例演示了这一点-

type Person(name) =
   member x.Name = name
   abstract Greet : unit -> unit
   default x.Greet() = printfn "Hi, I'm %s" x.Name

type Student(name, studentID : int) =
   inherit Person(name)

   let mutable _GPA = 0.0

   member x.StudentID = studentID
   member x.GPA
      with get() = _GPA
      and set value = _GPA <- value
   override x.Greet() = printfn "Student %s" x.Name

type Teacher(name, expertise : string) =
   inherit Person(name)
   let mutable _salary = 0.0
   member x.Salary
      with get() = _salary
      and set value = _salary <- value

   member x.Expertise = expertise
   override x.Greet() = printfn "Teacher %s." x.Name

//使用子类
let p = new Person("Mohan")
let st = new Student("Zara", 1234)
let tr = new Teacher("Mariam", "Java")

//default Greet
p.Greet()

//Overriden Greet
st.Greet()
tr.Greet()

编译并执行程序时,将产生以下输出-

Hi, I'm Mohan
Student Zara
Teacher Mariam.

抽象类

您不能创建抽象类的,因为该类尚未完全实现。

[<AbstractClass>]
type Person(name) =
   member x.Name = name
   abstract Greet : unit -> unit

type Student(name, studentID : int) =
   inherit Person(name)
   let mutable _GPA = 0.0
   member x.StudentID = studentID
   member x.GPA
      with get() = _GPA
      and set value = _GPA <- value
   override x.Greet() = printfn "Student %s" x.Name

type Teacher(name, expertise : string) =
   inherit Person(name)
   let mutable _salary = 0.0
   member x.Salary
      with get() = _salary
      and set value = _salary <- value
   member x.Expertise = expertise
   override x.Greet() = printfn "Teacher %s." x.Name

let st = new Student("Zara", 1234)
let tr = new Teacher("Mariam", "Java")

//Overriden Greet
st.Greet()
tr.Greet()

编译并执行程序时,将产生以下输出-

Student Zara
Teacher Mariam.

祝学习愉快!(内容编辑有误?请选中要编辑内容 -> 右键 -> 修改 -> 提交!)

技术教程推荐

微服务架构核心20讲 -〔杨波〕

Java核心技术面试精讲 -〔杨晓峰〕

深入剖析Kubernetes -〔张磊〕

玩转Spring全家桶 -〔丁雪丰〕

从0开发一款iOS App -〔朱德权〕

分布式数据库30讲 -〔王磊〕

程序员的个人财富课 -〔王喆〕

深入C语言和程序运行原理 -〔于航〕

PPT设计进阶 · 从基础操作到高级创意 -〔李金宝(Bobbie)〕

好记忆不如烂笔头。留下您的足迹吧 :)