密封类和封装函数、可不一样

密封类:
密封类是类的一种,用sealed修饰,不能用作基类。它也不能抽象类。密封类主要用于防止派生。

C#提出了一个密封类(sealed class)的概念,帮助开发人员来解决这一问题。

密封类在声明中使用sealed 修饰符,这样就可以防止该类被其它类继承。如果试图将一个密封类作为其它类的基类,C#将提示出错。理所当然,密封类不能同时又是抽象类,因为抽象总是希望被继承的。

sealed(参考)

sealed 修饰符可以应用于类、实例方法和属性。密封类不能被继承。密封方法会重写基类中的方法,但其本身不能在任何派生类中进一步重写。当应用于方法或属性时,sealed 修饰符必须始终与 override 一起使用。

在类声明中使用 sealed 修饰符可防止继承此类,例如:

sealed class SealedClass

{

public int x;

public int y;

}

将密封类用作基类或将 abstract 修饰符与密封类一起使用是错误的。

结构是隐式密封的;因此它们不能被继承。

示例

// cs_sealed_keyword.cs

using System;

sealed class SealedClass

{

public int x;

public int y;

}

class MainClass

{

static void Main()

{

SealedClass sc = new SealedClass();

sc.x = 110;

sc.y = 150;

Console.WriteLine("x = {0}, y = {1}", sc.x, sc.y);

}

}

输出

x = 110, y = 150

在前面的示例中,如果试图通过使用下面的语句从密封类继承:

class MyDerivedC: MyClass {} // Error

将收到错误信息:

'MyDerivedC' cannot inherit from sealed class 'MyClass'.

密封类正好与抽象类相反。抽象类型必须被继承,不能为一个抽象类型创建一个实例。相反地,密封类型不能被继承,它是具体的。密封类不能被派生类型细化,它是类层次结构中的终结节点。

sealed修饰符也可以应用在实例方法、属性、事件和索引器上,但是不能应用于静态成员。密封成员可以存在于密封或非密封类中。一个密封成员必须对虚成员或隐含虚成员进行重写,如抽象成员。但是,密封成员自己是不能被重写的,因为它是密封的。sealed修饰符必须与override修饰符结合使用。虽然密封成员不能被重写,但是一个在基类中的密封成员可以用new修饰符在派生类中进行隐藏。重要的是,CLR可以对密封成员进行优化。

以下代码展示了一个密封类和一个密封成员。在这个例子中,HourlyEmployee类不能被进一步地细化。此外,HourlyEmployee.Pay方法不能被重写。

public abstract class Employee {

public virtual void Pay() { 

}

public abstract void CalculatePay();

}

public sealed class HourlyEmployee: Employee {

public sealed override void Pay() {

    CalculatePay();

}

public override void CalculatePay() {

}

}


封装函数:

//只读封装
public class Department
{
private string department;
public Department(string str)//有参构造函数
{
department = str;
}
public string DepartmentName
{
get { return this.department; }
}

}
public class Tester
{
    static void Main(string[] args)
    {
        Department pm = new Department("myName");
        Console.WriteLine("pm.DepartmentName is:{0}", pm.DepartmentName);
        Console.Read();

    }问题:调用有参构造函数时应该是把字符串"naName"赋值给了私有字段department了吧?那为什么

Console.WriteLine()内部要写pm.DepartmentName而不写department呢????

//2:只写封装
public class SetPart
{
private string setpart;
public string Setpartname
{
set
{
setpart = value;
Console.WriteLine("the Setpartname is:{0}",setpart);
Console.Read();
}
}
}
public class Tester
{
static void Main(string[] args)
{
SetPart s=new SetPart();
s.Setpartname= "my name";

    }
}//问题:这个测试函数部分是怎样的执行过程啊?语句s.Setpartname= "my name"就是给属性赋值吧?为什么会执行了  Console.WriteLine()?而且内部为什么不写s.Setpartname而写setpart呢?

转载于:https://www.cnblogs.com/bb-love-dd/p/5928837.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值