类C存在两个x成员,分别从A和B继承。若c是class C的实例,可以用c.A::x这种用法,但c.x会因为歧义引起编译错误(注意这里的成员名称解析在访问权限之前,改变访问权限无法避免歧义)。注意对于类名C直接使用成员操作符“.”是错误的,另外这里若x是C的static成员对象,则可以使用C::x或c.x引用这个成员。测试代码:
class A
{
public:
int x;
};
class B
{
public:
int x;
};
class C: public A, public B
{
public:
} c; //这里顺便定义一个实例。
int main()
{
c.A::x++; //++只是为了防止引起“无意义语句”的编译警告,逻辑上无意义,下同。
c.B::x++;
c.x++; //编译错误:歧义的成员名称x。
return 0;}
另外:
struct I1
{
virtual void f() = 0;
};
struct I2
{
virtual int f() = 0;// 只有返回值不同
};
struct A :public I1,public I2
{
void f()
{
}
int f()
{
return0;
}
};
这样编译会报错:
error C2555: 'A::f': overriding virtual function return type differs and is not covariant from 'I2::f'
解决方案:
struct I1
{
virtual void f() = 0;
};
struct I2
{
virtual int f() = 0;// 只有返回值不同
};
struct A :public I1,public I2
{
void f1()
{
this->I1::f();
}
int f2()
{
return this->I2::f();
}
};
}