C语言笔试深度经典,没准备好老鸟可能都会入坑

这篇博客探讨了C语言中的若干难点和易错点,包括类型转换、字符串处理、变量作用域、指针与内存操作、内存对齐、运算符优先级等。文章通过举例说明了如符号和无符号整数相加、strcpy函数的潜在风险、静态变量与全局变量的区别、数组与指针的关系、sizeof运算符的应用,以及const关键字的用法等,并讲解了内存访问错误和递归函数的执行过程。
摘要由CSDN通过智能技术生成

答案就在代码下面

  • 1.下面的代码输出是什么?为什么?
  • 2.下面的代码有什么问题?为什么?
  • 3.下面的代码,i 和 j 的值分别是什么?为什么?
  • 4.下面代码里,假设在 32 位系统下,各 sizeof 计算的结果分别是多少?
  • 5.下面代码的结果是多少?为什么?
  • 6.下面的代码里,哪些内容可被改写,哪些不可被改写?
  • 7.下面的两段代码有什么区别?什么时候需要使用代码(2)
  • 8. 在 32 位的 x86 系统下,输出的值为多少?
  • 9. 0x01<<2+3 的值为多少?为什么?
  • 11.下面的两段代码有什么区别?
  • 12.写代码向内存 0x12ff7c 地址上存入一个整形数 0x100。
  • 13.下面的代码输出是多少?
  • 15.下面代码输出地结果是多少?
  • 16.下面的代码有什么问题?为什么?
  • 17.下面的代码有什么问题?为什么?
  • 18.下面的代码输出结果是多少?
  • 19.下面的代码有什么问题?为什么?
  • 20.请写一个C函数,若当前系统是Big_endian的,则返回0;若是little_endian的,则返回1。本题的意思即写一个小函数测试数据在当前编译器下是“大端”存储还是“小端”存储

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])
{
   
    sizeof(b);         
}

//sizeof(b)的值是 ------->4函数传参是只是传入一个地址,这里是求的是地址大小

5.下面代码的结果是多少?为什么?

size_t zstrlen(char
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值