const修饰的虚函数实例如何实现?
- 内容介绍
- 文章标签
- 相关推荐
本文共计436个文字,预计阅读时间需要2分钟。
在C++中,`const`关键字用于修饰变量和函数,以限制它们的可修改性。以下是对`const`修饰虚拟函数实例的简单解释:
cpp// 程序1
// 使用const修饰虚拟函数实例,意味着即使派生类覆盖了该函数,也无法通过const对象调用它。class Base {public: virtual void func() const { // 函数体 }};
class Derived : public Base {public: void func() override { // 函数体 }};
int main() { const Base* ptr=new Derived(); // 指向const对象的指针指向非const对象 ptr->func(); // 正常调用,无需const const Base* const ptrConst=ptr; // 指向const对象的指针指向const对象 ptrConst->func(); // 错误:无法通过const对象调用非const函数 return 0;}
C++ 中const修饰虚函数实例详解
程序1
#include <iostream> using namespace std; class Base { public: virtual void print() const = 0; }; class Test : public Base { public: void print(); }; void Test::print() { cout << "Test::print()" << endl; } void main() { // Base* pChild = new Test(); //compile error! // pChild->print(); }
程序2
#include <iostream> using namespace std; class Base { public: virtual void print() const = 0; }; class Test : public Base { public: void print(); void print() const; }; void Test::print() { cout << "Test::print()" << endl; } void Test::print() const { cout << "Test::print() const" << endl; } void main() { Base* pChild = new Test(); pChild->print(); } /* Test::print() const */
程序3
#include <iostream> using namespace std; class Base { public: virtual void print() const = 0; }; class Test : public Base { public: void print(); void print() const; }; void Test::print() { cout << "Test::print()" << endl; } void Test::print() const { cout << "Test::print() const" << endl; } void main() { Base* pChild = new Test(); pChild->print(); const Test obj; obj.print(); Test obj1; obj1.print(); Test* pOwn = new Test(); pOwn->print(); } /* Test::print() const Test::print() const Test::print() Test::print() */
备注:一切皆在代码中。
总结:const修饰成员函数,也属于函数重载的一种范畴。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
本文共计436个文字,预计阅读时间需要2分钟。
在C++中,`const`关键字用于修饰变量和函数,以限制它们的可修改性。以下是对`const`修饰虚拟函数实例的简单解释:
cpp// 程序1
// 使用const修饰虚拟函数实例,意味着即使派生类覆盖了该函数,也无法通过const对象调用它。class Base {public: virtual void func() const { // 函数体 }};
class Derived : public Base {public: void func() override { // 函数体 }};
int main() { const Base* ptr=new Derived(); // 指向const对象的指针指向非const对象 ptr->func(); // 正常调用,无需const const Base* const ptrConst=ptr; // 指向const对象的指针指向const对象 ptrConst->func(); // 错误:无法通过const对象调用非const函数 return 0;}
C++ 中const修饰虚函数实例详解
程序1
#include <iostream> using namespace std; class Base { public: virtual void print() const = 0; }; class Test : public Base { public: void print(); }; void Test::print() { cout << "Test::print()" << endl; } void main() { // Base* pChild = new Test(); //compile error! // pChild->print(); }
程序2
#include <iostream> using namespace std; class Base { public: virtual void print() const = 0; }; class Test : public Base { public: void print(); void print() const; }; void Test::print() { cout << "Test::print()" << endl; } void Test::print() const { cout << "Test::print() const" << endl; } void main() { Base* pChild = new Test(); pChild->print(); } /* Test::print() const */
程序3
#include <iostream> using namespace std; class Base { public: virtual void print() const = 0; }; class Test : public Base { public: void print(); void print() const; }; void Test::print() { cout << "Test::print()" << endl; } void Test::print() const { cout << "Test::print() const" << endl; } void main() { Base* pChild = new Test(); pChild->print(); const Test obj; obj.print(); Test obj1; obj1.print(); Test* pOwn = new Test(); pOwn->print(); } /* Test::print() const Test::print() const Test::print() Test::print() */
备注:一切皆在代码中。
总结:const修饰成员函数,也属于函数重载的一种范畴。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

