C语言面试题每天10道题 ——第二天

1:对地址直接操作时要进行强制转换,否则会报类型不匹配
这里写图片描述

2;防止头文件重复定义
自定义头文件与系统定义头文件搜索的开始不同
堆栈 堆是堆 栈是栈
这里写图片描述

3;宏
定义宏一定要多打括号
定义宏来满足两个功能
交换两个数 不能使用第三变量
比较大小 使用三目
这里写图片描述
宏来测试数组的元素个数
这里写图片描述

4;带参宏 带参函数 内联函数inline
这里写图片描述

5;valitele 不进行优化 每次都到内存中取值
这里写图片描述

6:static与const的用途
这里写图片描述

7;全局变量
两种使用方法 头文件 和 extren
这里写图片描述

8;用宏定义来完成位运算
直接用宏来置位、复位(最右边为第1位)。

#define SET_NTH_BIT(x, n)  (x | ((1U)<<(n-1)))
#define CLEAR_NTH_BIT(x, n) (x & ~((1U)<<(n-1)))

截取变量的部分连续位。例如:变量0x88, 也就是10001000b,若截取第2~4位,则值为:100b = 4

#define GETBITS(x, n, m) ((x & ~(~(0U)<<(m-n+1))<<(n-1)) >> (n-1)) 

分析:这个题目相当于我们4.2.4.5中做的事情,只不过要用宏来实现。
这个题目相当于是要把x的bit(n-1)到bit(m-1)取出来
复杂宏怎么分析:

((x & ~(~(0U)<<(m-n+1))<<(n-1)) >> (n-1))
第一步,先分清楚这个复杂宏分为几部分:2部分
(x & ~(~(0U)<<(m-n+1))<<(n-1)) >> (n-1)
分析为什么要>>(n-1),相当于是我们4.2.4.5中的第二步

第二步,继续解析剩下的:又分为2部分
x & ~(~(0U)<<(m-n+1))<<(n-1)
分析为什么要&,相当于我们4.2.4.5中的第一步

第三步,继续分析剩下的:
~ (~(0U)<<(m-n+1)) << (n-1)
这个分析时要搞清楚第2坨到底应该先左边取反再右边<<还是先右边<<再左边取反。
解法:第一,查C语言优先级表;第二,自己实际写个代码测试。
说明这个式子应该是 ~(~(0U)<<(m-n+1)) << (n-1) ,这就又分为2部分了

10001000
00001110
00001000

9;static变量,
static的全局变量和函数 作用域只在本文件
其他文件要使用全局变量则可以使用extren 或者定义头文件中

static全局变量只初使化一次,下一次依据上一次结果值;

把局部变量改变为静态变量后是改变了它的存储
方式即改变了它的生存期。把全局变量改变为静态变量后是改变了它的
作用域,限制了它的使用范围。

static函数与普通函数有什么区别?
【标准答案】static函数在内存中只有一份,普通函数在
每个被调用中维持一份拷贝

程序的局部变量存在于_栈 中,全局变量存在于
数据段若未进行初始化则默认为0在bss段中,动态申请数据存在于_堆 中。
【标准答案】程序的局部变量存在于栈(stack) 中,全局
变量存在于静态数据区中,动态申请数据存在于堆(
heap)中。

10
用预处理指令#define 声明一个常数,用以表
明1年中有多少秒(忽略闰年问题)
【参考答案】

#define SECONDS_PER_YEAR (60 * 60 * 24 * 365)UL

因为计算出的这个数刚好超过 unsinged int

  • 11
    点赞
  • 95
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值