繁体   English   中英

是否可以通过指向子类对象的父类类型引用变量访问不在父类中的子类成员?

[英]Is it possible to access child class members that are not in parent class from a parent class type reference variable pointing to child class object?

根据我的理解,如果我有一个指向子类对象的父类类型引用变量:

ParentClass obj= new ChildClass();

obj.OnlyMembersThatHavebeenDerivedFromParentAreAvailable// am i wrong? 

在下面的示例中,我应点击此处,我应该无法访问AnnualSalary

派生类:

 public class FullTimeEmployee : Employee
    {
        public int AnnualSalary { get; set; }
    }

派生类:

public class PartTimeEmployee : Employee
    {
        public int HourlyPay { get; set; }
        public int HoursWorked { get; set; }
    }

家长班

 public class Employee
    {
        private int _id;
        private string _name;
        private string _gender;
        private DateTime _dateOfBirth;

        [DataMember(Order = 1)]
        public int Id
        {
            get { return _id; }
            set { _id = value; }
        }

        [DataMember(Order = 2)]
        public string Name
        {
            get { return _name; }
            set { _name = value; }
        }

        [DataMember(Order = 3)]
        public string Gender
        {
            get { return _gender; }
            set { _gender = value; }
        }

        [DataMember(Order = 4)]
        public DateTime DateOfBirth
        {
            get { return _dateOfBirth; }
            set { _dateOfBirth = value; }
        }

        [DataMember(Order = 5)]
        public EmployeeType Type { get; set; }
    }

以下代码如何有效?

Employee employee = null;
 employee = new FullTimeEmployee
                        {
                            Id = Convert.ToInt32(reader["Id"]),
                            Name = reader["Name"].ToString(),
                            Gender = reader["Gender"].ToString(),
                            DateOfBirth = Convert.ToDateTime(reader["DateOfBirth"]),
                            Type = EmployeeType.FullTimeEmployee,
                            AnnualSalary = Convert.ToInt32(reader["AnnualSalary"]) // how is AnnualSalary available here? 
                        };

是的,你不能写:

employee.AnnualSalary = 1234;

但这不是您的情况。
您仅使用对象初始化程序来初始化FullTimeEmployee对象(您可以访问所有公共字段/属性)。
基本上,您正在执行以下操作:

FullTimeEmployee employeeTemp = new FullTimeEmployee();
employeeTemp .AnnualSalary =2000;
Employee employee =employeeTemp;

更新资料

我认为不能将父类对象转换为子类对象,因为孩子可以做父级可以做的所有事情,反之亦然。

再一次,你是对的。
再一次,这不是你的情况...
该方法的返回类型可能是Employee,但是您返回的实际对象可能是其他东西(派生类)。
在这种情况下,您可以安全地将对象强制转换为派生类型。
检查以下示例

namespace CastExample
{
  class Program
  {
    static void Main(string[] args)
    {
        Employee emp = GetEmployee();
        FullTimeEmployee full = (FullTimeEmployee)emp;
        System.Console.WriteLine(full.AnnualSalary);
        PartTimeEmployee part = (PartTimeEmployee)emp;//InvalidCastException
        System.Console.ReadLine();
    }

    static Employee GetEmployee()
    {
        return new FullTimeEmployee() { Name = "George", AnnualSalary = 1234   };
    }
  }
  public class Employee
  {
     public string Name;
  }
  public class FullTimeEmployee : Employee
  {
     public int AnnualSalary { get; set; }
  }
  public class PartTimeEmployee : Employee
  {
      public int HourlyPay { get; set; }
      public int HoursWorked { get; set; }
  }
}

而且他也可以使用私有财产?

是的,您可以使用反射访问私有字段
通过反射找到私人领域?
如何获得C#中private字段的值?
C#使用反射从派生类获取私有成员变量

检查一下: 为什么在C#中可以反射访问受保护的/私有类成员?
@Marc Gravell的答案解释了为什么可以这样做,但要特别注意@Tamas Czinege的答案(我在这里再次引用)

成员可访问性不是安全功能 它可以保护程序员免受自己的侵害。 它有助于实现封装,但绝不是安全功能。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM