首页 > 代码库 > 从C到C++ (1)

从C到C++ (1)

从C到C++

一、 bool类型

   bool取值false和true,是0和1的区别; false可以代表0,但true有很多种,并非只有1。

二、 const限定符

  1. 常量在定义后就不能修改,所以定义时必须初始化。
  2. 在一个文件全局作用域中定义非const变量,在另外的文件中做extern声明,就可以使用这个变量。但是,对于一个文件全局作用域中定义的const变量,在另外的文件中做extern声明,是不能被访问的:
                      //文件一

                               const int counter=func();

                               //文件二

                               extern const int counter;

                               ++counter; //这里变量声明后不可以用

          这里const变量要想能够被其他的文件访问,必须显示的指定它为extern:

                              //文件一

                     extern const int counter=func();
                     //文件二
                     extern const int counter;
                     ++counter; //这里变量声明后可以用

   3. const  int  *p ;  // *p为常量,经由*p不能更改指针所指向的内容。

           int *  const  p;  // p为常量,不能更改p指向,可以更改p所指向的内容。

     4. const 与 #define区别

    1) const定义的常量有类型,而#define定义的常量没有类型,编译可对前者做类型安全检查,而后者仅仅是做简单替换。

        2) const定义的常量在编译时分配内存,而#define定义的常量在预编译时进行替换,不分配内存,程序加载到内存时才分配内存。

        3)  作用域不同,const定义的常变量的作用域为该变量的作用域范围。而#define定义的常量作用域为它的定义点到程序结束,当然也可以在某个地方用#undef取消。

    定义常量还可以用enum。高层编译尽量用enum、const替换#define定义常量。底层编译#define有很大的灵活性。

三、 结构体内存对齐

  1. 为什么要对齐:

          数据存在与对齐的内存地址中CPU读取数据的速度大大提升

     2. 如何对齐:

      4) 第一个数据成员对齐至偏移值为0的地方

    5) 接下来的数据成员对齐(start)至对齐模数的整数倍。

            对齐模数 = 数据成员的大小与pragma pack(n) (对齐值gcc(4) vc(8))的较小值 注意gcc对齐数的取值是0 1 2 4

      6) 每个成员都有自己的对齐数 最总整个结构体对齐至成员最大对齐数的倍数。

  例:

                               typedef struct  test
                               {
                                                          char ch1;//start 0       size=1 end=1
                                                          double d;//mix(8:8)=8 -> start 8(对齐至8的整数倍)   size=8 end=16
                                                          char ch2;//mix(1:8)=1 -> start 16(对齐至1的整数倍)  size=1 end=17
                               }test_t;   //last 17:8x end=24 整个结构体大小为8的倍数即24