classes base abstratas, herança múltipla e métodos virtuais puros comuns

O código de teste a seguir parece indicar que, se uma classe tiver duas classes base abstratas com métodos virtuais puros comuns, esses métodos serão "compartilhados" na classe derivada.

#include <iostream>
#include <string>

using namespace std;

struct A
{
    virtual string do_a() const = 0;
    virtual void set_foo(int x) = 0;
    virtual int get_foo() const = 0;
    virtual ~A() {}
};

struct B
{
    virtual string do_b() const = 0;
    virtual void set_foo(int x) = 0;
    virtual int get_foo() const = 0;
    virtual ~B() {}
};

struct C : public A, public B
{
    C() : foo(0) {}
    string do_a() const { return "A"; }
    string do_b() const { return "B"; }
    void set_foo(int x) { foo = x; }
    int get_foo() const { return foo; }
    int foo;
};

int main()
{
    C c;
    A& a = c;
    B& b = c;
    c.set_foo(1);
    cout << a.do_a() << a.get_foo() << endl;
    cout << b.do_b() << b.get_foo() << endl;
    cout << c.do_a() << c.do_b() << c.get_foo() << endl;
    a.set_foo(2);
    cout << a.do_a() << a.get_foo() << endl;
    cout << b.do_b() << b.get_foo() << endl;
    cout << c.do_a() << c.do_b() << c.get_foo() << endl;
    b.set_foo(3);
    cout << a.do_a() << a.get_foo() << endl;
    cout << b.do_b() << b.get_foo() << endl;
    cout << c.do_a() << c.do_b() << c.get_foo() << endl;
}

Este código é compilado corretamente em g ++ 4.1.2 (reconhecidamente antigo), usando -std = c ++ 98 -pedantic -Wall -Wextra -Werror. A saída é:

A1
B1
AB1
A2
B2
AB2
A3
B3
AB3

Isso é o que desejo, mas questiono se isso funciona em geral, ou apenas "por acaso". Fundamentalmente, esta é a minha pergunta: posso depender desse comportamento ou devo sempre herdar de uma classe base virtual para esse tipo de cenário?

questionAnswers(1)

yourAnswerToTheQuestion