C#中的一些方法修饰关键字virtual override sealed new

对于方法(属性、事件)

1. 如想重写(扩展和修改继承)方法要求有两个

    a. 基类必须是virtual

    b. 继承类型的同签名方法必须override也就是说基类和继承类都必须同意,重写才能实现

2. 刚才只是说了只继承了一层的情况,但如果有多层集成,比如CClass:BClass:AClass

    a. B中的某个方法M1override A中的M1来的,这时如果C再重写M1的时候,就不要求BM1virtual关键字修饰了。重写(override)来的方法,默认也同意被其子类override(即便没有virtual其实也不能有virtual)

    b. 当然如果不同意其子类重写这个方法也可以,override的时候加上sealed

3. 如果子类主动不想跟父类的同名方法有什么瓜葛,不带override就可以了,但是这样编译器会给个警告,如果不想看警告可以new一下,主动声明跟父类没啥瓜葛。

    a. new的方法默认是不能被其子类重写的

    b.new可以跟virtual合伙,表明欢迎子类重写这个方法(只有virtual也可以,多个编译警告)

    c. 只要跟父类有同签名方法new就可以存在,不论父类是否允许他的方法被重载

4. 除了virtual还有abstract关键字,abstractvirtual还彻底,基类干脆就不实现任何功能了,就等着子类来override,所以abstract肯定也是同意做被派生类重载的。

总结几种方法的修饰组合及其结果

    virtual:同意被重载

    abstract:本方法没内容,派生类一定要记得重载我哦,除非派生类也是抽象的

    override:同意重载父类的同名方法也同意被自己的子类重载

    override sealed:同意重载父类但不同意被自己的子类重载(sealed只是配合override的,自己不会单独跑出来)

    什么修饰都没有:不同意重载父类也不同意子类重载自己

    new:特此声明,父类的同名方法跟我无关

    virtual new:父类同名方法跟我无关,不过欢迎子类重载我

样例:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace Example03
{
    class Program
    {
        static void Main(string[] args)
        {
            AClass a = new CClass();
            a.M1();
            a.M2();
            a.M3();
            a.M4();
            a.M5();
            a.M6();
            a.M7();
            a.M8();
            Console.WriteLine("-");
            BClass b = new CClass();
            b.M1();
            b.M2();
            b.M3();
            b.M4();
            b.M5();
            b.M6();
            b.M7();
            b.M8();
            Console.ReadLine();
        }
    }
    public class CClass : BClass
    {
        public override void M1()
        {
            Console.WriteLine("C.M1");
        }
        public new void M2()
        {
            Console.WriteLine("C.M2");
        }
        public void M3()//(有编译警告)
        {
            Console.WriteLine("C.M3");
        }
        public new void M4()
        {
            Console.WriteLine("C.M4");
        }
        public override void M5()
        {
            Console.WriteLine("C.M5");
        }
        public new void M6()
        {
            Console.WriteLine("C.M6");
        }
        public new void M7()
        {
            Console.WriteLine("C.M7");
        }
        public new void M8()
        {
            Console.WriteLine("C.M7");
        }
    }
    public abstract class BClass : AClass
    {
        public override void M1()//重写父类 允许子类重写自己
        {
            Console.WriteLine("B.M1");
        }
        public override void M2()//重写父类 允许子类重写自己
        {
            Console.WriteLine("B.M2");
        }
        public override void M3()//重写父类 允许子类重写自己
        {
            Console.WriteLine("B.M3");
        }
        public new void M4()//不重写父类 不允许子类重写自己
        {
            Console.WriteLine("B.M4");
        }
        public new virtual void M5()//不重写父类 允许子类重写自己
        {
            Console.WriteLine("B.M5");
        }
        public new virtual void M6()//不重写父类 允许子类重写自己
        {
            Console.WriteLine("B.M6");
        }
        public override sealed void M7()//重写父类 不允许子类重写自己
        {
            Console.WriteLine("B.M7");
        }
        public virtual void M8()//不重写父类 允许子类重写自己(有编译警告)
        {
            Console.WriteLine("B.M8");
        }
    }
    public class AClass
    {
        public virtual void M1()
        {
            Console.WriteLine("A.M1");
        }
        public virtual void M2()
        {
            Console.WriteLine("A.M2");
        }
        public virtual void M3()
        {
            Console.WriteLine("A.M3");
        }
        public virtual void M4()
        {
            Console.WriteLine("A.M4");
        }
        public virtual void M5()
        {
            Console.WriteLine("A.M5");
        }
        public virtual void M6()
        {
            Console.WriteLine("A.M6");
        }
        public virtual void M7()
        {
            Console.WriteLine("A.M7");
        }
        public virtual void M8()
        {
            Console.WriteLine("A.M8");
        }
    }
}

运行结果:

C.M1
B.M2
B.M3
A.M4
A.M5
A.M6
B.M7
A.M8
-
C.M1
B.M2
B.M3
B.M4
C.M5
B.M6
B.M7
B.M8

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值