继承中的同名成员变量和同名成员函数

一句话:派生类的同名成员屏蔽基类同名成员,转而调用自身成员。

			若想调用基类同名成员,需要加上域操作符(::)
			举例:class Parent
				{
					public:
					int a;
					void printP()
					{
						cout<<"a"<<a<<endl;
					}
				};

				class Child:public Parent
				{
					public:
					int a;
					void printC()
					{
						cout<<"a"<<a<<endl;
					}
				};

			void main()
			{
				Child a1;
				a1.a = 100;
				a1.printP();
				a1.printC();
				a1.Parent::a = 200;
				a1.printP();
				a1.printC();

				system("pause");
			}
### C++ 继承中隐藏成员变量的行为解决方案 在 C++ 中,当一个派生类继承基类时,可能会出现派生类中的成员变量或函数隐藏了基类中的同名成员变量或函数的现象。这种行为通常发生在以下几种情况下: #### 1. 隐藏成员变量的原因 在 C++ 中,派生类的成员变量基类成员变量是独立的实体[^3]。如果派生类定义了一个与基类同名成员变量,则该变量会隐藏基类中的同名成员变量。例如: ```cpp class Base { protected: int value; public: Base(int v) : value(v) {} void print() { cout << "Base value: " << value << endl; } }; class Derived : public Base { private: int value; // 隐藏了基类的 value 成员变量 public: Derived(int v1, int v2) : Base(v1), value(v2) {} void printDerived() { cout << "Derived value: " << value << endl; } }; ``` 在此示例中,`Derived` 类中的 `value` 成员变量隐藏了 `Base` 类中的 `value` 成员变量。这意味着在 `Derived` 的作用域内,直接使用 `value` 将引用派生类的成员变量,而不是基类成员变量。 #### 2. 解决方案 为了解决隐藏成员变量的问题,可以采取以下方法: - **通过限定符访问基类成员变量** 在派生类中,可以通过使用限定符(如 `Base::value`)来显式访问基类成员变量。例如: ```cpp void Derived::printBaseValue() { cout << "Base value (via qualifier): " << Base::value << endl; } ``` 这种方式明确指定了要访问的是基类成员变量[^3]。 - **避免同名成员变量** 最简单的解决方案是确保派生类中的成员变量名称与基类中的成员变量名称不同。这样可以避免隐藏问题的发生。例如,将派生类中的 `value` 改名为 `derivedValue`。 - **使用 getter setter 方法** 如果需要在派生类中访问基类成员变量,可以通过在基类中定义公共的 getter setter 方法来实现。例如: ```cpp class Base { protected: int value; public: Base(int v) : value(v) {} int getValue() const { return value; } // Getter 方法 void setValue(int v) { value = v; } // Setter 方法 }; class Derived : public Base { private: int derivedValue; public: Derived(int v1, int v2) : Base(v1), derivedValue(v2) {} void printValues() { cout << "Base value: " << getValue() << endl; // 使用基类的 getter 方法 cout << "Derived value: " << derivedValue << endl; } }; ``` 这种方式不仅解决了隐藏问题,还提高了代码的封装性可维护性。 #### 3. 示例代码 以下是一个完整的示例,展示了如何解决继承中隐藏成员变量的问题: ```cpp #include <iostream> using namespace std; class Base { protected: int baseValue; public: Base(int v) : baseValue(v) {} int getBaseValue() const { return baseValue; } // Getter 方法 void setBaseValue(int v) { baseValue = v; } // Setter 方法 }; class Derived : public Base { private: int derivedValue; public: Derived(int v1, int v2) : Base(v1), derivedValue(v2) {} void printValues() { cout << "Base value (via getter): " << getBaseValue() << endl; // 使用基类的 getter 方法 cout << "Derived value: " << derivedValue << endl; } void updateBaseValue(int newValue) { setBaseValue(newValue); // 使用基类的 setter 方法 } }; int main() { Derived d(10, 20); d.printValues(); d.updateBaseValue(100); d.printValues(); return 0; } ``` #### 4. 总结 在 C++ 的继承机制中,派生类的成员变量可能隐藏基类同名成员变量。这种行为的根本原因是派生类基类成员变量是独立的实体。为了解决这一问题,可以通过限定符显式访问基类成员变量、避免同名成员变量或使用 getter setter 方法来间接访问基类成员变量。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值