C++要点回顾(谭爷爷的书)

变量的引用

  • 在C++中,变量的引用就是变量的别名alias
  • 对一个变量的引用的所有操作,实际上都是对其所代表的原来的变量的操作
    变量a,别名为b
    int a;
    int &b=a;
    声明b是一个引用变量,初始化为a
    经过这样的声明之后,使用a或b的作用相同
    type * var 声明了一个指针变量
    type & 声明了一个引用变量
  • 声明一个变量的引用后,在本函数执行期间,该引用不可以变更为其他变量的引用
  • &何时为引用,何时为取地址
    &前面有type时为引用,elsewise为取地址
  • 将引用作为函数参数
void swap(int&a, int&b)
{
  int temp=a;
  a=b;
  b=temp;
}
  • 形参不是另外一个变量,而是实参的引用,与实参同占一个存储单元,也就是说改形参就可以改实参

inline function:compile时,将内联函数嵌入到main里,以空间换时间,适用于规模小且频繁调用的函数

作用域运算符:有个全局变量a,有个局部变量a,在局部,用a会屏蔽全局a,如果真想用a,通过::a

动态分配/回收内存的运算符new和delete
new int //allocate a space, return a ptr
new int(100) //eval the initial val
new int[10] //allocate a space to store array, in this case, you cannot specify initial val

float* p=new float(3.14);
float* parr=new float[10];
delete p;
delete[] ptr;

无参数的构造函数
Box b 而不是b()

类对象数组 Box b[3]={Box(参数), Box(参数), Box(参数)}

指向普通函数的指针:
void (p)( )
可以使它指向一个函数
p=&fun
可以通过该指针变量,调用该函数
(
p)( )

指向成员函数的指针
void (Time::*p)()

普通函数: 类型名 (指针变量名)(参数列表)
成员函数: 类型名 (类名::
指针变量名)(参数列表)

数据既能共享,又不会被修改,使用const
如果一个对象为const,那么它不可以call非const的成员

类名 *const 指针变量名 = 对象地址
这是个常指针,只能指向一开始确定的那个对象

const 类名*指针变量名
这个是指向常变量的指针,可以换别的常对象

静态定义对象,在runtime,对象所占的空间是不能随时释放的
想要提高内存的利用率,可以动态建立和释放对象
用new运算符动态地分配内存后,将返回一个指向新对象的指针
Box* p=new Box(12,13,14);
程序可以通过这个p访问对象
在执行new运算时,如果内存量不足,返回一个0
delete p;
memberwise copy

静态数据成员,为所有类对象所共享,只能在类外面进行初始化
类名::静态变量

友元函数:可以是普通函数,也可以是其他类的成员函数
友元函数可以访问私有变成员
用关键字friend声明友元函数
如果是其他类的成员函数作为友元函数,要提前声明其他类

运算符重载:
格式——类型 operator 运算符名(参数表)
{重新定义运算规则}
注意 operator 运算符名 就是函数名,其他的和普通函数没什么区别

对>>和<<进行重载,只能作为普通函数不可以作为成员函数
istream & operator >>(istream &, 自定义类 &)
ostream & operator >>(ostream &, 自定义类 &)

#include 
using namespace std;

class Complex{
private:
    float re;
    float im;
public:
    Complex():re(0),im(0){};
    Complex(float r,float i):re(r),im(i){};
    //Complex operator +(Complex& a);
    //void show();
    friend ostream & operator<<(ostream & nout,Complex &c);
    friend Complex operator + (Complex &a,Complex &b);
    friend istream & operator>>(istream & nin,Complex &c);
};

/*Complex Complex::operator +(Complex& a){
    float real,imag;
    real=a.re+re;
    imag=a.im+im;
    return Complex(real,imag);
}*/
istream & operator>>(istream & nin,Complex &c){
    cout<<"Enter real and imaginary part:"<>c.re>>c.im;
    return nin;
}
ostream & operator<<(ostream & nout,Complex &c){
        if(c.im==0){
        nout<>u>>v;
    Complex w;
    w=u+v;
    cout<

你可能感兴趣的:(C++要点回顾(谭爷爷的书))