加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

C# – 传递自身对象的继承方法

发布时间:2020-12-15 23:29:32 所属栏目:百科 来源:网络整理
导读:真正的问题是反射和装配修补/挂钩.我将举一个简单的例子来展示我的问题,而不是太难理解主要问题. 所以让我们想象一下我有这些基本类: public class Vehicle{ public string Name; public string Price; public void DoSomething() { Main.Test(this); }}pub
真正的问题是反射和装配修补/挂钩.我将举一个简单的例子来展示我的问题,而不是太难理解主要问题.

所以让我们想象一下我有这些基本类:

public class Vehicle
{
    public string Name;
    public string Price;

    public void DoSomething()
    {
        Main.Test(this);
    }
}

public class Car : Vehicle
{
    public int Wheels;
    public int Doors;
}

在主要代码上我运行它:

public class Main
{
    public void Start()
    {
        Car testCar = new Car()
        {
            Name = "Test Car",Price = "4000",Wheels = 4,Doors = 4
        };

        testCar.DoSomething();
    }

    public static void Test(Vehicle test)
    {
        // Is this allowed ?
        Car helloWorld = (Car) test;
    }   
}

好的,问题是:

是否允许转换(在静态方法测试中)?我会失去汽车的属性,但保留车辆属性?

如果它是错的,有没有其他方法可以做到这一点?

谢谢.

解决方法

只有当传入的物体恰好是Car时才允许使用Vehicle to Car.否则你会得到一个例外.

有一个强制转换,当类型错误时不会导致异常:

Car car = test as Car;

这将永远不会抛出,但当Vehicle不是Car时,可变汽车将为null.您可以添加if条件来测试强制转换是否成功:

Car car = test as Car;
if (car != null) {
    ...
}
Bus bus = test as Bus;
if (bus != null) {
    ...
}
Rv rv = test as Rv;
if (rv != null) {
    ...
}

但是,C#提供了一个更好的解决方案:方法重载可以让你完全避免投射.

public class Main {
    public static void Test(Car test) {
        ... // This method will be called by Main.Test(this) of a Car
    }
    public static void Test(Bus test) {
        ... // This method will be called by Main.Test(this) of a Bus
    }
    public static void Test(Rv test) {
        ... // This method will be called by Main.Test(this) of an Rv
    }
}

这是有效的,因为当您进行Main.Test(this)调用时,编译器知道此变量的确切类型.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读