C++面向对象高级编程(一)基础篇
技术在于交流、沟通,转载请注明出处并保持作品的完整性。
概要:
知识点1 构造函数与析构函数
知识点2 参数与返回值
知识点3 const
知识点4 函数重载(要与重写区分开)
知识点5 友元
先以C++的两大经典class(complex 不含指针, string 含指针)之一 complex(复数类) 做例子.
#ifndef complex_hpp //防止头文件重复 #define complex_hpp #include <stdio.h> class complex { public: //知识点1 构造与析构函数(见下文) complex(double r = 0, double i = 0) : re(r) ,im(i) {} //知识点2 参数与返回值(见下文) complex& operator += (const complex& r); //知识点3 const(见下文) double real() const { return re; } double imag() const { return im; } //知识点4 函数重载(见下文) void real(double r); private: double re,im; //知识点5 友元(见下文) friend complex& __doapl (complex*, const complex&); }; //知识点6 内联(见下文) inline complex&__doapl (complex* ths, const complex& r) { ths->re += r.re; ths->im += r.im; return *ths; } #endif /* complex_hpp */
知识点1 构造函数与析构函数
a. 构造函数不可以直接调用,他是有我们创建之后自动调用的函数
b.上面我写的是带初省值的构造函数(就是带红色:),则你不可以再声明不带参数而带有出省值的构造函数
complex () : re(0) , im(0) {} //如果你在声明这样的构造函数 会报错.因为下面的两个初始化 编译器会识别不出该调用哪个 complex c1; complex c2();
c.如果将构造函数与析构函数声明private权限下,则外界不可以随便创建该对象,应用实例单例设计模式(这个我会在C++设计模式的文章中做详细介绍)
d.可用下面三种方式创建对象
complex c2;//默认构建 栈 complex c1(2,1);//初始值构建 栈 complex* p = new complex(4);//动态构建 堆
e.析构函数,不可以直接调用,对象销毁时自动调用,不带指针的类多半可以不用写析构函数
f.对象的创建有两个过程 1.初始化,2.赋值,所以带出省值的构造函数(给成员变量赋值)比 不该出省值的构造函数内部赋值 创建对象更有效率
知识点2 参数与返回值
参数 : 参数传递的三种形式 pass by value(将整包东西穿过去,效率低) , pass by pointer(传递指针), pass by reference(传递引用,类似指针,建议使用)
a.介绍一下引用,引用相当于取别名,必须初始化,之后不能再引用其他变量,不能引用null
b.传递引用效率高,且比传递指针更加漂亮,传递引用4字节(你可能会说传递char 1字节,比引用快,具体情况具体分析嘛)
void func_int(int a); //pass by value void func_char(char* i);//pass by point void func()_class(const complex&);//pass by reference
返回值 : 三种形式同参数,效率任然是by reference更高,但是要注意,不要返回局部对象的引用
错误实例
int& func() { int a = 0; return a; //函数调用结束后,局部变量a将销毁,返回局部变量引用无意义 }
知识点3 const
先介绍一下const的作用,使"其"不能变.
a.const声明普通变量, 即常量,必须初始化
const int a = 10;
b.const声明指针
const int* p1;//不能改变其指向的数据 int const *p2;//同上 int* const p3;//不能改变其指向
c.const声明成员变量,常量成员,需要在构造函数中初始化
d.const声明函数
//在class中 const void func(); //不能调用非const成员函数
像complex中函real()的const
double real() const { return re; }//可以理解成常量成员函数 const member functions 不可以改变变量 只能get 不能set //如果你不声明const的话 const complex c1(2,1); cout << c1.real(); //会报错 --- 因为c1是const变量 该函数可能修改其变量
要大胆的使用const,会给你带来无限的好处.
知识点4 函数重载(要与重写区分开)
a.不同的函数可以具有相同的函数名,前提是形参列表不同(参数个数不同,参数类型不同)
b.不能通过返回值得类型不同进行函数重载
知识点5 友元
a.frend声明的函数 优点:实现类之间数据共享时,减少系统开销,提高效率 . 缺点 友元函数破环了封装机制
b.同一个class的各个object 互为 friend (友元)
complex c1(2,1); complex c2; //c1与c2互为友元
c.高效率
friend complex& __doapl (complex*, const complex&); //可以直接使用其私有成员变量 效率会高于其他函数如"set()"函数
知识点6 内联
a.inline内联函数,效率高,即使你将函数声明称inline也可能内联不成功,内联函数实现控制在5行内.
效率与推荐
a. 带出省值的构造函数
b. return/pass by reference
c. 友元
d. 内联
e. move() //我在格式工厂(四)中有介绍
如有不正确的地方请指正
参照<<侯捷 C++面向对象高级编程>>
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步