《C语言深度解剖》20道习题解析

1.下面的代码输出是什么?为什么?

void foo(void)
{
    unsigned int a = 6; int b = -20;
    (a + b>6)? puts(">6"):puts("<=6");
}

答案:输出  >6
原因:当表达式中存在有符号类型和无符号类型时所有的操作数都自动转换为无符号类型。
6的补码:00000000 00000000 00000000 00000110
-20补码:11111111 11111111 11111111 11110010
相加后按照无符号形式输出:4294967282 >6。


2.下面的代码有什么问题?为什么?

void foo(void)
{
    char string[10],str1[10]; 
    int i;
    for(i=0; i<10; i++) 
    str1[i] = ’a’;
    strcpy(string , str1); 
    printf(“%s”,string);
}

答案:程序运行崩溃
原因:strcpy在运行时只有碰到‘\0’时才会停下来,而字符数组string在初始化时末尾并没有‘\0’,所以在拷贝时会一直向后找‘\0’,直至访问越界。


3.下面的代码,i 和 j 的值分别是什么?为什么?

static int j; 
int k=0;

void fun1(void)
{
    static int i=0;
    i++;
}

void fun2(void)
{
    j=0;
    j++;
}

int main()
{
    for(k=0;k<10;k++){
        fun1();
        fun2();
    }
    return 0;
}

答案:i = 10;j = 1;
原因: i  声明在函数内部是局部变量,保存在内存栈当中。当它被关键字static修饰后,便保存在静态区且它的值只会初始化一次。当局部变量被static修饰后改变为静态变量,它的生存期变长,但作用域变。
    j 声明在所有的函数之外,是全局变量。 当全局变量被static修饰后,变量的作用域变窄(只在当前文件中有效),且生命周期不变 (所以每被调用一次就会被初始化一次)
   注意:函数形参不允许被static声明
   另外,当函数被static修饰后改变的是函数的链接属性使其成为静态函数,函数的作用域仅局限于本文件(所以又称内部函数)。


4.下面代码里,假设在 32 位系统下,各 sizeof 计算的结果分别是多少?

int *p=NULL;
//sizeof(p)的值是       ------>4 p是一个指针变量,占四个字节      
//sizeof(*p)的值是      ------>46
// sizeof括号内部的内容不参加运算,所以并不会计算*p是什么,由于p是int*类型的所以返回4    
int a[100]; 
//sizeof(a)的值是       ------->400  数组名单独出现在sizeof中表示整个数组
//sizeof(a[100])的值是  ------->4  
//  sizeof括号内的表达式并不进行计算,只是计算类型的空间占用量,(a[])
//sizeof(*(a+100))的值是------->4  因为a是int型数组,这里并不计算a+100指向哪里   
//sizeof(&a)的值是      ------->4  地址的内存占用量在32位机器下永远是4个字节(64位下为8字节)
//sizeof(&a[0])的值是   ------->4   同上

int b[100];
void fun(int b[100])
{
    
  • 10
    点赞
  • 56
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值