Java继承和活动

时间:2013-05-30 08:23:48

标签: java android inheritance

我有一个A类,它自己解析一个xml文件。   B类扩展A并配置自己解析一个xml文件,该文件具有比前一个更多的标记。

class A {
  protected String mFoo;

  protected loadFromXml (...){
     ...
     mFoo = ...
     ...
  }
}

class B extends A {
    protected String mBar;

    protected loadFromXml (...){
    super.loadFromXml(...);

    ...
    mBar = ...
    ...
    }
}

现在,我有ActivityA通过A类配置自己:

class ActivityA extends Activity {

protected A mAInstance;

    public void onCreate(Bundle savedInstanceState) {
        ...
        mAInstance.loadFromXml(...);
    ...
    other code...
        ...
    }
}

和ActivityB:

class ActivityB extends ActivityA{

   protected B mBInstance;

   public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

    ...
    mBInstance.loadFromXml(...);
...
   }
}

现在,问题是:ActivityB持有mAInstance和mBInstance,它们共享相同数据的子集(mFoo)。如何只加载mBInstance?我当然需要在ActivityB中调用onCreate中的super ...

3 个答案:

答案 0 :(得分:1)

首先,我假设ActivityB扩展了ActivityA,否则无法从ActivityB访问A.

然后,您可以从B中删除mBInstance,因为您已经有一种类型的A已经可用。 加载xml时,将对loadFromXML的调用移动到新方法,如:

在ActivityA中:

protected onCreate(...) {
 ....
 loadXML();
}

protected void loadXML() {
  getNewInstance().loadFromXML();
}

protected A getNewInstance() {
  return new A();
}

然后在ActivityB中,您需要仅将getNewInstance()覆盖为:

protected A getNewInstance() {
 return new B();
}

mBInstance.loadFromXml(...);移除ActivityB#onCreate(...) 多态到救援!

答案 1 :(得分:0)

我会使用多态并将loadFromXml()调用移动到受保护的方法,如gunar所示。您还需要解决如何使用正确的类型访问AB的实例。这是一个例子:

课程AB

class A {
   public String mFoo;
   protected void loadFromXml() {}
}

class B extends A {
    public String mBar;

    @Override
    protected void loadFromXml() {}
 }

班级ActivityA

class ActivityA {
    private A mAInstance; // do not access this directly, use getter

    protected A getMInstance() { // getter
        return mAInstance;
    }

    @override
    public void onCreate() {
        initMInstance();
    }

    protected void initMInstance() {
        mAInstance = new A();
        mAInstance.loadFromXml();
    }

    private void f() {
        String s = getMInstance().mFoo; // access mAInstance like this
    }
}

班级ActivityB

class ActivityB extends ActivityA {
    private B mBInstance;

    @Override
    protected B getMInstance() { // override getter, ActivityA will see type A, activityB type B
        return mBInstance;
    }

    @Override
    public void onCreate() {
        initMInstance();
    }

    @Override
    protected void initMInstance() {
        mBInstance = new B();
        mBInstance.loadFromXml();
    }

    private void f() {
        String s1 = getMInstance().mFoo; // here you can access both properties
        String s2 = getMInstance().mBar;
    }
}

答案 2 :(得分:-1)

B.loadFromXml()进行

super.loadFromXml(...);

您根本不会影响实际情况。由于它不是静态的,我假设您正在更新其中的this属性而不创建任何新实例;您将更新B实例,即使它是A类中的代码。