个人觉的不可理解.....以下是原话然而,尽管在Manager类中没有显式地的定义getName和getHireDay等方法,但属于Manager类的对象却可以使用它们,这是因为Manager类自动地继承了超类Employee中的这些方法。
同样,从超类中还继承了name,salary和hireDay这3个域。这样一来,每个Manager类对象就包括了4个域:name,salary,hireDay和bonus.代码如下/**
   @version 1.21 2004-02-21
   @author Cay Horstmann
*/import java.util.*;public class ManagerTest
{  
   public static void main(String[] args)
   {  
      // construct a Manager object
      Manager boss = new Manager("Carl Cracker", 80000, 1987, 12, 15);
      boss.setBonus(5000);      Employee[] staff = new Employee[3];      // fill the staff array with Manager and Employee objects      staff[0] = boss;
      staff[1] = new Employee("Harry Hacker", 50000, 1989, 10, 1);
      staff[2] = new Employee("Tommy Tester", 40000, 1990, 3, 15);      // print out information about all Employee objects
      for (Employee e : staff)
         System.out.println("name=" + e.getName()
            + ",salary=" + e.getSalary());
   }
}class Employee
{  
   public Employee(String n, double s, int year, int month, int day)
   {  
      name = n;
      salary = s;
      GregorianCalendar calendar = new GregorianCalendar(year, month - 1, day);
      hireDay = calendar.getTime();
   }   public String getName()
   {
      return name;
   }   public double getSalary()
   {  
      return salary;
   }   public Date getHireDay()
   {  
      return hireDay;
   }   public void raiseSalary(double byPercent)
   {  
      double raise = salary * byPercent / 100;
      salary += raise;
   }   private String name;
   private double salary;
   private Date hireDay;
}class Manager extends Employee
{  
   /**
      @param n the employee's name
      @param s the salary
      @param year the hire year
      @param month the hire month
      @param day the hire day
   */
   public Manager(String n, double s, int year, int month, int day)
   {  
      super(n, s, year, month, day);
      bonus = 0;
   }   public double getSalary()
   { 
      double baseSalary = super.getSalary();
      return baseSalary + bonus;
   }   public void setBonus(double b)
   {  
      bonus = b;
   }   private double bonus;
}
居然说私有域也被继承了。。后面又花了点时间解释,怎么可能?

解决方案 »

  1.   

    没有错啊,这是翻译的时候使用的术语不同。严格的说,父类的私有成员(包括成员变量和方法)一样被子类继承到了,它们在子类中仍然存在:在子类的对象中,仍然存在空间存储这些私有的成员变量。但是,在子类的方法里,不可以通过名字来直接访问这些成员,如果一定要访问,需要在父类中定义访问私有成员的公有方法,子类会继承这些公有方法,从而可以通过这些公有方法来间接访问从父类继承过来的私有成员。所谓“父类的私有成员不能被子类继承”、“父类的私有成员被继承,并且成为子类的成员”等等说法,都只是不同的作者习惯用词的不同。严格的理解是:父类的私有成员确实被子类继承到了,它在子类中依然存在,只不过,它没有“真正”成为子类的成员,因为在子类的方法里,不能通过名字直接访问它。
      

  2.   

    不能访问 也存在空间存储?有证据没?怎么证明?那私有方法是不是也被继承了?就是不能访问?
      

  3.   

    有证据。你可以生成一个子类的对象,看看它占据的内存大小就知道了。
      

  4.   

    私有方法当然也被继承,只是不能通过名字访问而已。
      

  5.   

    原来是以前把继承理解错了!