C++ 运算符 [] & *、操作符new 修饰符const inline virtual

1. [] 

  这让我想到静态分配内存和动态分配内存,与数据名称无关

  局部变量和临时变量会储存在静态缓存区,随着程序运行完而消亡(例如在循环体中定义的局部变量随着循环体结束,局部变量也会消亡)。

  内存泄漏是指:就是内存驻留了指针存在了未指向的内存空间的地址值。

  例子:声明一个指针对象,指针指向的结果为对象在内存中动态分配的空间,其后在操作中又将另一对象的内存地址赋给它,最后没有对之前指针指向的内存空间进行delete.

int *old   = new int;
int *new = new int
//delete old
*old = *new
cout<<*old<<endl;

2. * 指针

  指针就是变量,在程序中将经常用到指针,其中应该理解:指针、内存地址值、位置、地址所在内存中的值

  int *point = new int(1);  //指针-*point   内存地址值-point   位置-point   地址所在内存中的值-1

3. &

  隐式指针, 在C语言中这个符号表示了取地址符,但是在C++中它却有着不同的用途,可提高程序执行效率和代码的健壮性!

  int a; int &ya=a; //定义了引用ya,它是变量a的引用(别名)      参考:C++中引用(&)的用法和应用实例

1)&在此不是求地址运算,而是起标识作用。

  (2)类型标识符是指目标变量的类型。

  (3)声明引用时,必须同时对其进行初始化。

  (4)引用声明完毕后,相当于目标变量名有两个名称,即该目标原名称和引用名,且不能再把该引用名作为其他变量名的别名。

   ra=1; 等价于 a=1;

  (5)声明一个引用,不是新定义了一个变量,它只表示该引用名是目标变量名的一个别名,它本身不是一种数据类型,因此引用本身不占存储单元,系统也不给引用分配存储单元。故:对引用求地址,就是对目标变量求地址。&ra与&a相等。

  (6)不能建立数组的引用。因为数组是一个由若干个元素所组成的集合,所以无法建立一个数组的别名。

  应用:

    1. 引用作为参数

    函数的传递方式有两种:传值、传址。 传值方式为C语言常见的,往往是将数据压入栈中(由编译器自动释放空间,栈的初始大小是由操作系统硬件决定),影响效率。如果是将引用作为参数传递,速度和效率不用说了.

    swap(a,b) 和swap(&a,&b);

4. new 

  操作符动态分配内存。 通常情况下会声明一个指针,指针的值就是new操作符为某个数据类型动态分配一个足够大的内存空间。

5. const

  不容改变的

6. inline

  适当加入此修饰能提高程序的运行效率

  inline void getElements(DataType *data);

7. virtual

  此修饰符有点像多态的意思,当基类中的某函数被virtual修饰时(public),程序调用此函数,则会执行继承该基类的派生类中的方法。

  

class A
{
public:
    A() {}
    virtual void foo()
    {
        cout << "This is A." << endl;
    }
};
class B : public A
{
public:
    B() {}
    void foo()
    {
        cout << "This is B." << endl;
    }
};
int main(int argc, char* argv[])
{
    A *a = new B();
    a->foo();
    if(a != NULL)
        delete a;
    return 0;
}
excute:
This is B.
 

 

你可能感兴趣的:(virtual)