c++ 易错题

来源:互联网 发布:遗传算法 机械应用 编辑:程序博客网 时间:2024/06/05 20:20

1.宏定义:

#include<iostream>using namespace std;#define add(a,b) a+bint main(){    cout<<5*add(3,4)<<endl; //结果是5*3+4=17}

2.枚举值

枚举类型限定了变量的取值

#include<iostream>using namespace std;#define add(a,b) a+bint main(){    enum num1{        one,        two,        three    } Num1,Num2,Num3;    Num1=one;    Num2=two;    Num3=three;    enum num2{        a,        b=5,        c           } Num2_1,Num2_2,Num2_3;    Num2_1=a;    Num2_2=b;    Num2_3=c;    cout<<"num1-one="<<Num1<<" num1-two="<<Num2<<" num1-three="<<Num3<<endl;//0,1,2    cout<<"num2-a="<<Num2_1<<" num2-b="<<Num2_2<<" num2-c="<<Num2_3<<endl;//0,5,6    /*       1.枚举类型的默认值为从0开始,后一个值比前一个大一。       2.如果改变默认值,则该位置往下的值依然比前面大一,该位置前面的保持不变    */

3.const常量

const定义的常量只能在定义时赋值,且之后不能修改。

#include<iostream>using namespace std;#define add(a,b) a+bint main(){   const int a;   a=2;//出错,必须在定义时初始化   cout<<a; }

4.参数传递顺序

#include<iostream>using namespace std;int f(int a,int b, int c){    return 0;}int main(){    return f(printf("a"),printf("b"),printf("c"));//依次输出cba}

1.c++的参数传递顺序是从右到左的
2.printf()函数形式 ,可见参数格式是int类型,故不会报错

int printf ( const char * format, ... );

5.结构体存储对齐问题

  • 结构体成员按照存储数据类型自身的对齐(即是:存储该变量的首地址%该变量类型所占字节=0)。
  • 结构体按照结构体数据成员的最大储存值对齐。
    看一下例子(假设是在32位系统下)32位下各数据类型及其所占字节。
char1个字节char*(即指针变量): 4个字节(32位的寻址空间是2^32, 即32个bit,也就是4个字节。同理64位编译器)short int : 2个字节int4个字节unsigned int : 4个字节float:  4个字节double:   8个字节long:   4个字节long long:  8个字节unsigned long:  4个字节

结构体如下

struct B{    char b;//首地址0,0%1=0,首地址符合 故地址0-1自己存储b    int a;//地址2开始,2%4=2不满足对齐,跳到地址4(4%4=0),故4-7字节单元存储b    short c; //8%2=0,满足,故8-9存储c    /*故数据成员对齐后总共占用0-9即十字节,又根据结构体按照结构体数据成员的最大储存值对齐(10%4!=0)故增加到12字节(12%4=0);    */};
原创粉丝点击