9个回答
展开全部
各位都能不能答好点?
我来从那个define宏语句讲一下。首先,定义宏PR(ar),替换内容为printf("ar=%d ",ar)。
接着就是main函数了。首先,定义整型变量j,整型数组a[8]并初始化为“1,3,5,7,9,11,13,15”,以及整型指针p,并指向a[5](a+5为a[5]的地址)。
接着定义for循环,以j为控制变量,将它设为3,条件为j(如果j不为0,那就为true,反为false),每次执行完就j--。循环内容是个switch结构语句,下面我来详细说一下。
这个switch判断的变量为j,一共有3个判断(是1还是2还是3)。如果为1,那就什么都不执行也不跳出switch继续判断。如果为2,那就执行PR(*p++)(相当于printf("ar=%d ",*p++)并跳出switch,如果为3,那就执行PR(*(--p))(相当于printf("ar=%d ",*(--p))并跳出switch(因为这是最后一个case了)。
循环开始时,因为j为3,所以执行执行PR(*(--p))(相当于输出a[4],因为它输出的时指针p前4个地址,而数组地址是按照它的类型连环存储的。所以输出“ar=9 ”)并跳出switch。
接着j--继续。因为j现在为2,所以执行PR(*p++)。并跳出switch。注意,*与++是同级运算符,且从右往左,所以先执行p++再执行*p++。但又因为它是后缀++,所以优先级比*要差。因此执行顺序为先输出p指向的地址的内容,自己再自加。所以输出为“ar=9 ”(9为a[4]的内容)。
接着j--继续,因为j为1,所以什么都不执行。注意,这并不意味着也不执行下面的语句,case 1中是没有break的,所以会继续执行语句且不执行下面的判断,一直到结束或者遇到break。这时跳到下一个语句PR(*p++),按照我上一个讲的,这里会输出p指向的地址的内容,自己再自加。因为上一次p自加了,所以它现在指向的是a[5](即11)。所以输出“ar=11 ”
第四次j--后,因为j=0了,所以不能再执行。
所以输出结果为:ar=9 ar=9 ar=11
我来从那个define宏语句讲一下。首先,定义宏PR(ar),替换内容为printf("ar=%d ",ar)。
接着就是main函数了。首先,定义整型变量j,整型数组a[8]并初始化为“1,3,5,7,9,11,13,15”,以及整型指针p,并指向a[5](a+5为a[5]的地址)。
接着定义for循环,以j为控制变量,将它设为3,条件为j(如果j不为0,那就为true,反为false),每次执行完就j--。循环内容是个switch结构语句,下面我来详细说一下。
这个switch判断的变量为j,一共有3个判断(是1还是2还是3)。如果为1,那就什么都不执行也不跳出switch继续判断。如果为2,那就执行PR(*p++)(相当于printf("ar=%d ",*p++)并跳出switch,如果为3,那就执行PR(*(--p))(相当于printf("ar=%d ",*(--p))并跳出switch(因为这是最后一个case了)。
循环开始时,因为j为3,所以执行执行PR(*(--p))(相当于输出a[4],因为它输出的时指针p前4个地址,而数组地址是按照它的类型连环存储的。所以输出“ar=9 ”)并跳出switch。
接着j--继续。因为j现在为2,所以执行PR(*p++)。并跳出switch。注意,*与++是同级运算符,且从右往左,所以先执行p++再执行*p++。但又因为它是后缀++,所以优先级比*要差。因此执行顺序为先输出p指向的地址的内容,自己再自加。所以输出为“ar=9 ”(9为a[4]的内容)。
接着j--继续,因为j为1,所以什么都不执行。注意,这并不意味着也不执行下面的语句,case 1中是没有break的,所以会继续执行语句且不执行下面的判断,一直到结束或者遇到break。这时跳到下一个语句PR(*p++),按照我上一个讲的,这里会输出p指向的地址的内容,自己再自加。因为上一次p自加了,所以它现在指向的是a[5](即11)。所以输出“ar=11 ”
第四次j--后,因为j=0了,所以不能再执行。
所以输出结果为:ar=9 ar=9 ar=11
追问
蟹蟹
展开全部
不是每个人都能得出想要的结果。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这个是给程序猿出的题目吧
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
重拍,看不清
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询