#define声明一个常数,用以表明1年中有多少秒(忽略闰年问题)。答案:#defineSECONDS_PER_YEAR(60*60*24*365)UL应该意识到表达式将使一个16位机的整形数溢出,因此要用到长整型符号L,表达式中UL表示无符号长整型。“标准”宏MIN,这个宏输入连个参数并返回较小的一个。答案:#defineMIN(A,B)((A)<=(B)?(A):(B))*ss1=”0123456789”;charss2[]=”0123456789”;charss3[100]=”0123456789”;intss4[100];charq1[]=”abc”;charq2[]=”a\n”;char*q3=”a\n”;答案:ss1是一个字符指针,指针的大小是一个确定的值,就是4,sizeof(ss1)=4;ss2是一个字符数组,这个数组最初的大小未定,填充值是“0123456789”,一个字符占一位,再加上隐含的“\0”一共是11位。ss3是一个字符数组,这个数组开始预分配100,所以它的大小是100位。ss4是一个整型数组,但是每个整型变量所占空间是4,所以它的大小一共是400位。q1与ss2类似,占4位。Q2里面有一个“\n”,“\n”算作一位,加上隐含的,大小一共是3位。Q3是一个字符指针,指针得大小是一个定值,?#include<iostream>usingnamespacestd;classA{};classA2{chard,e;};structB{};structC{charx,y;};structD{intx,y;};main(){cout<<sizeof(A)<<endl;cout<<sizeof(A2)<<endl;A*p1=newA();Ap2;A*p3;cout<<sizeof(p1)<<endl;cout<<sizeof(p2)<<endl;cout<<sizeof(p3)<<endl;cout<<sizeof(B)<<endl;cout<<sizeof(C)<<endl;cout<<sizeof(D)<<endl;return0;}答案:对于一个类而言,即便它是一个空的类,编译器仍然要要给它一个空间,所以类A即便什么也没有,它的空间大小依然为1,而类A2大小是类中连个字符d,e之和,所以它的空间大小依然是2,至于p1,p2,p3,p1和p3是指针,大小是一致的,而且是定值,为4,p2是A的对象,所以它的大小和类A相等,为1,B和C得解释同A和A2,至于D,它和C不同点在于,结构体有两个整型变量,每个整型变量所占空间为4,所以D所占空间大小为8。最后结果是1,2,4,1,4,1,2,?#include<iostream>usingnamespacestd;classA1{public:inta;staticintb;A1();~A1();};classA2{public:inta;charc;A2();~A2();};classA3{public:floata;charc;A3();~A3();};classA4{public:floata;intb;charc;A4();~A4();};classA5{public:doubled;floata;intb;charc;A5();~A5();}intmain(){cout<<sizeof(A1)<<sizeof(A2)<<sizeof(A3)<<sizeof(A4)<<sizeof(A5)<<endl;return0;}答案:因为静态变量是存放在全局数据区的,而sizeof计算栈中分配的大小,是不会计算在内的,所以sizeof(A1)是4;为了照顾数据对其,int大小为4,char大小为1,所以sizeof(A2)是8;为了照顾数据对其,float大小为4,char大小为1,所以sizeof(A3)为8;为了照顾数据对其,float大小为4,int大小为4,char大小为1,所以sizeof(A4)为12;为了照顾数据对其,double大小为8,float大小为4,int大小为4,char大小为1,所以sizeof(A5)选择8的倍数为24。()charvar[]Inttest(charvar[]){retrunsizeof(var);}答案:因为var[]等价于*var,函数内部已经退化成一个指针了,()ClassB{float
软件工程师经典笔试题it笔试题 来自淘豆网m.daumloan.com转载请标明出处.