在结构体中,每个成员变量的偏移地址都是4的整数倍,在本题中,i的偏移地址为0,c的偏移地址为4+0=4,a的偏移地址为4+1=5,5不是4的倍数,所以默认系统补上3个空字符,所以a的偏移量就为8, 结构体的大小等最后一个变量的偏移地址+它的大小,所以test的大小就为8+4=12 !
这个题没有说明是否存在内存对齐,对齐的最小单位是什么。如果存在对齐,那么答案选D。
内存对齐的规则较复杂,简单来说,要保证每个变量的起始地址都能被它的长度整除。因此char c后需要补充3个字节以保证float a能够对齐。具体规则可以看相应教材或资料。
这道题看似简单,其实坑不少。
首先一点是关于自增长运算的,再就是函数传参的顺序。
自增长运算优先级高于函数传参顺序的;所以先计算自增长的++b;
作为函数的参数传入时,传参顺序是由右向左开始传到函数体的,对于本题调用f1时,就是先传b再传a,所以先计算形参b对应的实参最终值传进来,再计算a的。
c=f1(a+b,++b);
参数表从又开始传,所以先计算++b,第二个参数为9,再计算第一个参数a+b=6+9=15
最后计算c=f1(15,9); f1里的c=9%2=1,所以返回值为15+1=16
所以f2里的c=16.
其实这题如果把参数改为c=f1(++b,a+b)就更能体现自增长的优先级了。