C++知识整理(多益笔试) 20131012

前言:

         还是关于笔试知识的整理,主要是面向对象的知识还有一些常见的语法知识。

1.还是C++内存管理的知识

         C++中程序的内存分布如下:

         栈:向下增长,可读可写可执行;

         堆:向上增长,可读可写可执行;

         BSS数据段(就是存放未初始化的数据段):向上增长,可读可写不可以执行;如果程序员没有初始化,但是在这一个数据段中的数据会将内存清0,默认初始化是0.

         .data数据段:向上增长,可读可写不可以执行,就是存放的全局变量、静态变量的(已经初始化);

         .text 代码段:向上增长,可读可写不可以执行。

         分析一下程序中变量:

         局部变量、函数参数存放在栈中;静态局部变量,并不是在调用函数的时候分配,在函数返回的时候释放,而是像全局变量一样,静态的分配在数据段,作用只能在函数内部使用。

         堆,是动态费分配内存的空间;new malloc

         全局变量、静态变量位于数据段,未初始化的全局变量静态变量则是位于bss数据段。程序运行开始的时候,初始化为0,放在data段后面合称为数据区。但是不占用exe执行文件的大小。

         const修饰的全局变量在rodata只读数据段,const修饰的变量必须初始化,如果未初始化,将会被设置成为0,只读数据段和代码段在同一个段中。

         代码段:存储程序文本,指令指针就是在这里获取,一个段是可以被共享的。

2. 一个陷阱

int  a=5,b=6,c=7,d=8,m = 2,n = 2;

(m=a>b)&& (n=c>d);

 首先是运算符的优先级 > 的优先级是比 = 大的。然后就是问题出现的地方了:

(m= a>b) &&(n= c>d); 首先a>b 是错的,则m= 0,之后的表达式是不会被执行的,所以n依旧是2;

3.C++中只用普通的成员函数,析构函数可以使用虚函数,其他的构造函数、静态函数是不可以声明为virtual函数的。同时在析构函数中,声明析构函数式virtual类型,用于继承,当使用父类的指针指向子类的对象的时候,删除指针的时候,只会自动调用父类的析构函数,而不会调用子类的析构函数,这样会造成内存的泄露。所以子类的析构函数也需要使用virtual声明为析构函数,当delete指针的时候,也会自动调用子类中的析构函数。

         同时指针是不可以随便delete的,只有对于在堆中的对象的指针,才是可以删除的,否则运行的时候内存报错.

         Devried d;

    Base *pBase = &d;

    delete pBase;

 

虚析构函数

class Base{

public:

    Base(){

        cout << "Base:Base()" << endl;

    }

    virtual ~Base(){

        cout << "Base::~Base()" << endl;

    }

};

class Devried : public Base{

public:

    Devried(){

        cout << "Devried::Devried()" << endl;

    }

    ~Devried(){

        cout << "Devried::~Devried()" << endl;

    }

};

Base *pBase = new Devried();

delete pBase;

Base:Base()

Devried::Devried()

Devried::~Devried()

Base::~Base()

请按任意键继续. . .

4.C++不是一中类型安全性的编程语言,因为不同类型的指针可以互相转换,而C#是类型安全恶编程语言.

5.函数返回值是数组类型的时候,只是返回的数组的地址,而不是数组,所以这个数组在函数中必须是通过动态分配内存实现的,否则函数结束之后,会自动释放掉数组的栈空间。

6. 命令行参数

main.exe adv edf //argc = 3, 分别是 三个字符串,其中argv是指向字符指针的指针。

int main(int argc, char **argv)

{

         char *str,cx;

         cout << *argv << endl;

         cout << *++argv << endl;

         cout << (char) *((*argv)+1) << endl;

         int cn = 0;

         if(argc < 2){

                   return 0;

         }

}

7.对于unsigned int + int 值,都转成unsigned int 的类型。

但是返回结果赋值给其他的变量的时候,有会转为相应的类型

    int a = 14;

    unsigned int b = -20;

    cout << a+b << endl; // 很大的一个正数

    int c = a+b;  // -6

    cout << c << endl;

8.do{ } while(false);只会执行一次、

    int i = 0;

    do{

        i++;

        if(i < 16){

            printf("123");

        }

    }while(false);

9.printf("123"+"123");编译出错。

posted on 2013-11-05 22:52  追梦的飞飞  阅读(301)  评论(0编辑  收藏  举报